ajax html传递参数乱码问题,ajax在gb2312中乱码问题

在AJAX中用XMLHttpRequest发送请求时如用post方式传送数据,容易出现中文乱码问题!原因是Ajax中XMLHttpRequest对象的,默认编码方式是UTF-8。

AJAX中文问题分为两大类:

1)发送路径中的参数有中文,在服务器段接收参数值是乱码

例如:

var url="index.jsp?name=活力宝贝";

xmlHTTP.open ("post",url,true);

解决办法:

利用javascript的提供的escape()或encodeURI()方法

例如:

客户端:

var

url="index.jsp?name=活力宝贝";

url=encodeURI(url);

url=encodeURI(url); //两次,很关键[具体为什么,我也不清楚]

//或者 var

url="a.jsp?name=escape("活力宝贝")";

功能和encodeURI方法类似。

xmlHTTP.setrequestheader("cache-control","no-cache");

xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");

xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定发送数据的编码格式

xmlHTTP.open ("post",url,true);

服务器端:

String name = request.getParameter("name");

name = java.net.URLDecoder.decode("name", "UTF-8");

2)返回来的responseText或responseXML的值中含有中文是乱码

原因:AJAX在接收responseText或responseXML的值的时候是按照UTF-8的格式来解码的,如果服务器段发送的数据不是UTF-8的格式,那么接收responseText或responseXML的值有可能为乱码。

解决办法:

在服务器指定发送数据的格式:

在jsp文件中:

response.setContentType("text/text;charset=UTF-8");//返回的是txt文本文件

或是

response.setContentType("text/xml;charset=UTF-8");//返回的xml文件

JSP:response.setHeader("Charset","GB2312");

总结:

1)ajax提交数据的格式默认为utf-8,利用javascript的提供的escape()或encodeURI()方法.在服务器端接收的时候要使用java.net.URLDecoder.decode("","UTF-8")方法进行解码.

2)xtmlhttp

返回的数据默认的字符编码是utf-8,所以服务器要向客户端发送数据的时候,也要采用utf-8编码.如果上述方法仍然解决不了乱码问题,那你尝试一下把jsp,htm,java文件用UTF-8编码格式保存.

总之:前后台数据交互都采用utf-8编码就行了.

加上设置字符编码的方法:

response.setHeader("charset","gb2312");

看到的说明原文如下:

用AJAX中采用get来读取页面时,responseText里面的中文多半会出现乱码,这是因为xmlhttp在处理返回的responseText的时候,resposeBody默认采用utf-8编码,如果服务器送出的确实是utf-8的数据流的时候汉字会正确显示,而读取的页面编码是GBK或者GB2312时就会出现页面中文的乱码。

解决的办法有二:

1、在送出的流里面加一个header,指明送出的是具体编码流:

JSP:response.setHeader("Charset","GB2312");

2、采用utf-8编码来保存HTML文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值