AJAX乱码解决新方法
AJAX乱码解决新方法
发布时间:2016-12-29 来源:查字典编辑
摘要:用过AJAX的朋友肯定知道javascript是使用UTF-8国际编码,即每个汉字用3个字节来存储,但是这就造成了用AJAX来send数据的...

用过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);

?>

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新AJAX相关学习
热门AJAX相关学习
编程开发子分类