我们项目采用的字符编码是前后台清一色的utf8,我本来以为这样子就万事大吉了,不会出什么漏子的。可是谁知道ajax传过来的中文数据还是乱码。
原来在客户端是这样的 $.get("Discrete?q"+str,function(){......});其中str中包含了中文。
在服务端我们是用servlet来监听的
String qString = new String(request.getParameter("q"));,这个qString中就有乱码。
于是到网上找了一个超诡异的解决方案,现把解决方案公布如下:
首先在js加入辅助函数:
function EncodeUtf8(s1) { var s = escape(s1); var sa = s.split("%"); var retV =""; if(sa[0] != "") { retV = sa[0]; } for(var i = 1; i < sa.length; i ++) { if(sa[i].substring(0,1) == "u") { retV += Hex2Utf8(Str2Hex(sa[i].substring(1,5))); } else retV += "%" + sa[i]; } return retV; } function Str2Hex(s) { var c = ""; var n; var ss = "0123456789ABCDEF"; var digS = ""; for(var i = 0; i < s.length; i ++) { c = s.charAt(i); n = ss.indexOf(c); digS += Dec2Dig(eval(n)); } //return value; return digS; } function Dec2Dig(n1) { var s = ""; var n2 = 0; for(var i = 0; i < 4; i++) { n2 = Math.pow(2,3 - i); if(n1 >= n2) { s += 1; n1 = n1 - n2; } else s += 0; } return s; } function Dig2Dec(s) { var retV = 0; if(s.length == 4) { for(var i = 0; i < 4; i ++) { retV += eval(s.charAt(i)) * Math.pow(2, 3 - i); } return retV; } return -1; } function Hex2Utf8(s) { var retS = ""; var tempS = ""; var ss = ""; if(s.length == 16) { tempS = "1110" + s.substring(0, 4); tempS += "10" + s.substring(4, 10); tempS += "10" + s.substring(10,16); var sss = "0123456789ABCDEF"; for(var i = 0; i < 3; i ++) { retS += "%"; ss = tempS.substring(i * 8, (eval(i)+1)*8); retS += sss.charAt(Dig2Dec(ss.substring(0,4))); retS += sss.charAt(Dig2Dec(ss.substring(4,8))); } return retS; } return ""; }
接着在填写参数的时候,在你可能会用中文的地方进行两次encodeuri
str += encodeURI(encodeURI(spot.name)) + "," + spot.latLng.lat();
接着在添加url参数的时候,做这样一个事情,"Subway?q=" + EncodeUtf8(str))。
提交到服务器后,在servlet中这样写到:
String qString = new String(request.getParameter("q")); qString = URLDecoder.decode(URLDecoder.decode(qString, "utf-8"),"utf-8");
怎么样,很恶心吧?
后来我终于自己尝试出了一个新的更加有效的解决方案,客户端什么都不要做。只要在tomcat服务端
qString=URLDecoder.decode(URLEncoder.encode(qString,"ISO-8859-1"),"UTF-8");就可以了。