一、场景:
1、我在客户端要通过get方式调用服务器端的url,将中文参数做utf-8编码,需要在js中两次的进行编码,服务器端才能用decode方法一次获取。
例如:
- var xing=encodeURIComponent(encodeURIComponent(xing));
2、如果我在客户端用java输出汉字作为参数,并且用http协议,也是需要两次才能在服务器端正常的一次decode
- xing=URLEncoder.encode(xing,"UTF-8");
- xing=URLEncoder.encode(xing,"UTF-8");
二、原理:
因为在jsp中对中文进行了编码的时候用的是UTF-8的编码方式,而在servlet中调用request.getParameter();方法的时候使用服务器指定的编码格式自动解码一次,所以前台编码一次后台解码一次而解码和编码的方式不用所以造成了乱码的出现, 这就类似于以下代码:
String name=java.net.URLEncoder.encode("测试", "UTF-8"); System.out.println(name); System.out.println(java.net.URLDecoder.decode(name, "ISO-8859-1"));
编码后的是%E6%B5%8B%E8%AF%95。。 而用ISO-8859-1解码后的是???è?。。 但是如果调用的是
System.out.println(java.net.URLDecoder.decode(name, "UTF-8"));
String name=java.net.URLEncoder.encode("测试", "UTF-8"); System.out.println(name); name=java.net.URLEncoder.encode(name,"UTF-8"); System.out.println(name); name=java.net.URLDecoder.decode(name, "UTF-8"); System.out.println(name); System.out.println(java.net.URLDecoder.decode(name, "UTF-8"));