首页 > 开发 > AJAX > 正文

ajax中文乱码解决方法

2024-09-01 08:26:03
字体:
来源:转载
供稿:网友
用过ajax的朋友肯定知道javascript是使用utf-8国际编码,即每个汉字用4个字节来存储,但是这就造成了用ajax来send数据的时候出现乱码。

有一种解决办法就是使用encodeuricomponent加上修改 content-type 为 application/x-www-form-urlencoded" 来把数据统一编码成 url 格式,当然,也可以指定编码,如:“application/x-www-form-urlencoded; charset=utf-8 ”,例子:http_request = new activexobject("msxml2.xmlhttp"); http_request.setrequestheader("content-type","application/x-www-form-urlencoded; charset=utf-8");
另一种方法就是通过vbscript 的写的函数把数据转成gb2312格式的,我个人觉得这种方法比较好。有兴趣的朋友可以到网上去查一下。

也可以在js发送数据之前用escape函数把data转换为16进制的字符串,用js读取数据的时候再用unescape转换回来就ok了。

今天突发奇想,ajax调用的时候会不会发送cookie 呢?马上写了一个程序测试一下,果然能,这样就可以在调用ajax之前,先把数据通过javascript写到cookie里,然后再send就可以将cookie里的数据发送出去了,太爽了!!

演示地址:http://cn5.cn/ajax/ajax12.htm

客户端代码 ajax.htm
<title>ajax使用cookie传值例子</title>
<script>
var odiv
var xh
function getxml()
{
setcookie($('name').value,$('val').value);
odiv = document.all.m
odiv.innerhtml = "正在装载,请稍侯......."
odiv.style.display= ""
xh = new activexobject("microsoft.xmlhttp")
xh.onreadystatechange = getready
xh.open("post","a.php",false)
xh.send();
}

function getready()
{
if(xh.readystate==4)
{
if(xh.status==200)
{
odiv.innerhtml = "完成"
}
else
{
odiv.innerhtml = "抱歉,装载数据失败。原因:" + xh.statustext
}
}
} //author : longbill www.longbill.cn

function setcookie(name,value)
{
var cookiestr=name+"="+value+";";
var expires = "";
var cookieexp=60*60*1000;
var d = new date();
d.settime( d.gettime() + cookieexp);
expires = "expires=" + d.togmtstring()+";";
document.cookie = cookiestr+ expires;
}
function $(a)
{
return document.getelementbyid(a);
}
</script>

<body>
ajax使用cookie传值例子:<br/>
<form name=myform>
name:<input id=name value="变量名甚至可以是中文" size=20><br/>
value:<input type=text size=20 id=val value=这里><br/>
<input onclick="getxml()" type="button" value="送出数据">
<input onclick="if(xh && xh.responsetext) {alert(xh.responsetext);}" type="button" value="显示返回结果"><br/>
<div id=m bgcolor=blue>在此显示状态</div>
<input type=button onclick="alert(document.cookie)" value=显示本地cookie>
</form>


服务器端代码 a.php
<?
header("content-type: text/html;charset=gb2312");
echo "以下是您送出的所有cookie变量及其值/n";
print_r($_cookie);
?>


第一,javascript沿用java的字符处理方式,内部是使用unicode来处理所有字符的,
第二,utf-8是每个汉字(unicode字符)用3个字节来存储。
第三,用utf-8来send数据是不会出现乱码的,是后台程序没有正确解码才会出现乱码。
第四,ajax发送数据的时候如果修改 content-type 为 application/x-www-form-urlencoded",肯定是用post方式,而“太大的数据往往会出错”是用get方式发送数据造成的。
第五,用vbscript写的函数是用来把数据转成gbk编码(操作系统默认的编码方式。如果在繁体系统上就是big5之类的编码)的,而不是gb2312,两者的编码字符数量相差3倍左右。
第六,用cookie来发送数据,一是很容易溢出,二是要不停的擦屁股,否则cookie里面的数据在每个http请求(包括图片和脚本请求)中都会被发送。三是并发几个http请求的时候,没有办法指定那个cookie是要发送给那个http请求的。

用ajax来get回一个页面时,responsetext里面的中文多半会出现乱码,这是因为xmlhttp在处理返回的responsetext的时候,是把resposebody按utf-8编码进解码考形成的,如果服务器送出的确实是utf-8的数据流的时候汉字会正确显示,而送出了gbk编码流的时候就乱了。解决的办法就是在送出的流里面加一个header,指明送出的是什么编码流,这样xmlhttp就不会乱搞了。

php:header('content-type:text/html;charset=gb2312');
asp:response.charset("gb2312")
jsp:response.setheader("charset","gb2312");
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表