问题:JavaScript请求后台带着name参数,有中文进行编码:url?name=" + encodeURIComponent(name);java后台直接使用name或者name=java.net.URLDecoder.decode(name,"UTF-8")进行解码使用都是乱码。
解决方法一:
JavaScript:
window.location.href="/url?name="+encodeURIComponent(encodeURIComponent(name));
java:
name=java.net.URLDecoder.decode(name,"UTF-8");
为什么要两次编码的原因:后台java代码给searchtext赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页面上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");进行一次解码就好了。
解决方法二:
另外还有一种方法是JavaScript进行一次编码,后台java处理时换种想法就好了:
java代码:
String name = new String(name.getBytes("ISO8859-1"), "UTF-8");
这个问题跟我之前的博客内容有些关联:https://www.cnblogs.com/caozx/p/9628576.html