ajax乱码解决汇总
原文转自:http://blog.csdn.net/zhanngle/article/details/2063490
ajax乱码解决总结
第一,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");
方法一 (这种方法不怎么可靠)
向服务器发送请求,在服务器端加入:
String string = request.getParmater("parmater"); string = new String(string.getBytes("ISO8859-1"),"GBK"); 服务器向客户端发送报文: String static CONTENT_TYPE = "text/html;charset=GBK"; response.SetContentType(CONTENT_TYPE);
方法二(不推荐使用,URLDecoder.decode()与新浏览器不兼容)
Ajax POST 中文乱码解决
方法三(还可以) AJAX提交数据乱码,返回数据乱码的解决方案
xmlhttp.open("post"
,url,async );
xmlhttp.setRequestHeader("Content-Type","text/html" ); xmlhttp.send( params );
contentType="text/html; charset=UTF-8"
xmlhttp.setRequestHeader("Content-Type","text/html;charset=UTF-8");
response.setContentType("text/xml"
);
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html"
);
response.setCharacterEncoding("UTF-8"); 方法四(很保险,但代码量很大,是个不错的选择.) 在发送ajax请求之前,对参数escape()两次( 例:name=escape(escape("张三")); ),然后再发送请求到服务器,服务器接收参数后,对参数unescape(),就可以得到正确的参数( 例:String name=unescape(request.getParameter("name")); ). 附java版的unescape实现
public
staticStringunescape(Stringsrc)
{ StringBuffertmp=newStringBuffer(); tmp.ensureCapacity(src.length()); intlastPos=0,pos=0; charch; while(lastPos<src.length()) { pos=src.indexOf("%",lastPos); if(pos==lastPos) { if(src.charAt(pos+1)=='u') { ch=(char)Integer.parseInt(src.substring(pos+2,pos+6),16); tmp.append(ch); lastPos=pos+6; } else { ch=(char)Integer.parseInt(src.substring(pos+1,pos+3),16); tmp.append(ch); lastPos=pos+3; } } else { if(pos==-1) { tmp.append(src.substring(lastPos)); lastPos=src.length(); } else { tmp.append(src.substring(lastPos,pos)); lastPos=pos; } } } returntmp.toString(); } 附:prototype ajax乱码解决方法(已经过测试可行) prototype对传递的参数都进行了编码转换工作,每个传递值通过encodeURIComponent 进行了处理.编码会被转换成utf-8,在后台获取request时,应该统一使用request.setCharacterEncoding("UTF-8")对request设置编码,而不必管页面的编码格式是什么.如果使用post方法进行传递数据,则会自动执行: request.setHeader('Content-type','application/x-www-form-urlencoded').确保传递数据编码格式的正确. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |