日期:2014-05-16  浏览次数:20324 次

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