JavaScript在url中传接中文参数乱码解决方案
JavaScript在url中传递中文参数乱码解决方案
我有一段ajax代码(典型的ajax客户端代码),需要在url中传递中文参数:
function show() { var desc = document.search.desc.value; //desc的值有可能是中文 var url = "deal.jsp?desc=" + desc; // alert(url); if (window.XMLHttpRequest) { req = new XMLHttpRequest(); } else if (window.ActiveXObject) { req = new ActiveXObject("Microsoft.XMLHTTP"); } req.open("post", url, true); req.onreadystatechange = callback; req.send(null); } function callback() { if (req.readyState == 4) { if (req.status == 200) { // deal with the response text // alert(req.responseText); eval(req.responseText); } else { // 如果失败,刷新页面 alert(req.status + "\r\n" +req.responseText); window.location = location; } } }
在服务器端采用如下方式处理乱码:
desc = new String(desc.getBytes("ISO-8859-1"), "UTF-8"); // 会出现乱码
结果是:(1)网站部署在windows服务器上时,Chrome和FireFox会出现乱码,IE正常;
(2)网站部署在linux服务器上时,IE会出现乱码,Chrome和FireFox正常。
解决方案
No.1 在Javascript客户端,对中文参数进行两次encodeURI操作:
desc = encodeURI(desc); desc = encodeURI(desc); // 两次encodeURI转换
No.2 在服务器端,再进行解码:
desc = java.net.URIDecoder.decode(desc, "UTF-8");
经过这两步,无论window还是Linux做服务器,无论IE,Chrome还是FireFox,均无乱码,问题解决。
1 楼
KerryWang
2011-04-22
上述解决方案应该是针对普通js中的乱码。ajax乱码是由于我的疏忽,忘记了在服务器端设置response的属性,代码如下:
response.setContentType("text/xml;charset=utf-8");// (1)一定要在(2)的前面,不然会乱码 response.setCharacterEncoding("UTF-8"); // (2) response.setHeader("Cache-Control", "no-cache"); // HTTP 1.1 response.setHeader("Pragma", "no-cache"); // HTTP 1.0 response.setDateHeader("Expires", 0); // prevents catching at proxy server