用过AJAX的朋友肯定知道javascript是使用UTF-8国际编码,即每个汉字用3个字节来存储,但是这就造成了用AJAX来send数据的时候出现乱码。
有一种解决办法就是使用encodeURIComponent加上修改Content-Type为application/x-www-form-urlencoded"来把数据统一编码成url格式,但是这样做有一个弊端,使用php的urldecode根本不能得到正确的文字。
另一种方法就是通过vbscript的写的函数把数据转成gb2312格式的,我个人觉得这种方法比较好。有兴趣的朋友可以到网上去查一下。
今天突发奇想,AJAX调用的时候会不会发送cookie呢?马上写了一个程序测试一下,果然能,这样就可以在调用ajax之前,先把数据通过javascript写到cookie里,然后再send就可以将cookie里的数据发送出去了,太爽了!!
演示地址:http://cn5.cn/ajax/ajax12.htm
客户端代码ajax.htm
复制代码 代码如下:
<title>AJAX使用cookie传值例子</title>
<script>
varoDiv
varxh
functiongetXML()
{
setcookie($('name').value,$('val').value);
oDiv=document.all.m
oDiv.innerHTML="正在装载,请稍侯......."
oDiv.style.display=""
xh=newActiveXObject("Microsoft.XMLHTTP")
xh.onreadystatechange=getReady
xh.open("POST","a.php",false)
xh.send();
}
functiongetReady()
{
if(xh.readyState==4)
{
if(xh.status==200)
{
oDiv.innerHTML="完成"
}
else
{
oDiv.innerHTML="抱歉,装载数据失败。原因:"+xh.statusText
}
}
}//author:longbillwww.longbill.cn
functionsetcookie(name,value)
{
varcookiestr=name+"="+value+";";
varexpires="";
varcookieexp=60*60*1000;
vard=newDate();
d.setTime(d.getTime()+cookieexp);
expires="expires="+d.toGMTString()+";";
document.cookie=cookiestr+expires;
}
function$(a)
{
returndocument.getElementById(a);
}
</script>
<body>
AJAX使用cookie传值例子:<br>
<formname=myform>
name:<inputid=namevalue="变量名甚至可以是中文"size=20><br>
value:<inputtype=textsize=20id=valvalue=这里><br>
<inputonclick="getXML()"type="button"value="送出数据">
<inputonclick="if(xh&&xh.responseText){alert(xh.responseText);}"type="button"value="显示返回结果"><br>
<divid=mbgcolor=blue>在此显示状态</div>
<inputtype=buttononclick="alert(document.cookie)"value=显示本地COOKIE>
</form>
服务器端代码a.php
复制代码 代码如下:
<?
header("Content-type:text/html;charset=GB2312");
echo"以下是您送出的所有COOKIE变量及其值n";
print_r($_COOKIE);
?>