关于彻底解决Ajax异步调用时出现中文乱码的问题
今天帮同事解决了js异步调用时出现了中文乱码的问题,具体解决办法如下:
1)首先确认js是否没有对后台传输过来的中文进行解码。
按照网络上写的方法通过js对response的读取出来数据进行多次测试,发现仍然不能解决,细想不一定是此处问题。改换其他办法解决。
2)如果解码解决不了,再看是否是因为网络传输过来的时候编码。
在后台往前台js中页面回写数据之前,先设置response的传输编码为UTF-8(因为xmlHttp.responseText读取后台的传输字符的默认编码就是UTF-8),
后台java代码如下:
response.setCharacterEncoding("UTF-8");
PrintWriter out=response.getWriter();
String s = "123你好";
out.print(s); //往前台的js中回写响应信息
前台的js代码如下:
var xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
var url = "/test/RelateClitInfoQueryService?clitno=" + clitno;
xmlHttp.open("post",url,false);
xmlHttp.send();
//获取返回值
if(xmlHttp.responseText != null){
var clitinfo_tmp = xmlHttp.responseText;
//在java代码中添加response.setCharacterEncoding("UTF-8"); 后alert出来的中文就是正常的了,如果不加就是乱码(即?)
alert("clitinfo_tmp==" + clitinfo_tmp);
}
就此问题解决。希望此问题的解决对其他遇到乱码的朋友有所帮助。
相关文档:
工具:myeclipse 6.5
json中文官方:http://www.json.org/json-zh.html
新建项目webs,在WebRoot下新建目录json
xml的解析方式:
------------------------------------------------------------------
1.新建NewFile.xml
<?xml version="1.0" encoding="UTF-8"?>
<userinfo>
  ......
环境:Ajax+JSP,Tomcat5.05
参考:http://www.w3cschool.cn/index-24.asp.htm
文件:testAjax.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb ......
JavaScript 简单理解Ajax异步调用操作的文章。
文章地址:http://www.soaspx.com/dotnet/ajax/javascript/javascript_20090915_349.html
这篇文章是理解Ajax技术的简单例程,挺简明扼要,很容易理解。
Ajax提供与服务器异步通信的能力,借助于Ajax,可以在用户单击按钮时,使用JavaScript和 DHTML立即更新UI,并向服务器 ......
前段时间写JSP,使用AJAX以POST方式提交数据,如果是中文字符提交就会乱码,后来写ASP时用到AJAX以POST方式提交数据,中文一样是乱码。搜索一下相关资料,问题应该是提交数据时是以UTF-8编码提交,所以接收时如果使用GB2312或者其它中文编码的话就会乱码。
使用GET方式提交数据的时候,中文问题很好解决,setRequestHeader ......
test.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
<html xmlns=
"http://www.w3.org/1999/xhtml"
>
<head>
<meta http-equiv=
"Content-Type"
conten ......