一般浏览器传的中文参数时,取该参数转码一般是new String(request.getParameter("参数名").getBytes("ISO-8859-1"),"utf-8");这个样转码的。这样转码在本地上是没问题的,当把项目发布到服务器上时就可能出现乱码。解决方法是:
js:encodeURIComponent编码与解码
今天在js往jsp和servlet传参的时候出现:JavaScript用encodeURIComponentt编码后无法再后台解码的问题。
目前写法:
window.self.location="list.jsp?searchtext="+encodeURIComponent(seartext);
java处理的代码为:
searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");
咋一看觉的没问题,一编一解的,应该可以了。但还是出现了乱码。
原因:
原来在对后台java程序里的searchtext赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页面上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");进行一次解码就好了。
正确的代码:
JavaScript:
window.self.location="list.jsp?searchtext="+encodeURIComponent(encodeURIComponent(seartext));
java:
searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");
另外还有一种方法是JavaScript进行一次编码,后台java处理时换种想法就好了:
java代码:
String s = new String(request.getParameter("name").getBytes("ISO8859-1"), "UTF-8");