项目中遇到传递中文参数的问题,这个问题可以利用编码、解码解决。
方案:两次编码,一次解码。
编码:
var params = encodeURI(encodeURI("中文"));
把中文编码成由英文数字以及支付组成的一串code.
java端解码:
//params 就是“中文”
params = java.net.URLDecoder.decode(params , "UTF-8");
为什么要编码两次,而解码只需要一次?
因为servlet在接收参数的时候就会自动解码一次,并且默认是以ISO-8859-1进行解码的,所以前台需要编码两次,后台只需要手动用UTF-8解码一次。
使用两次编码的过程相当于如下代码:
String name;
name = java.net.URLEncoder.encode("测试", "UTF-8");
System.out.println(name);
name=java.net.URLEncoder.encode(name,"UTF-8");
System.out.println(name);
String NameUTF8=java.net.URLDecoder.decode(name, "UTF-8"); // 这行和name=java.net.URLDecoder.decode(name, "ISO-8859-1");结果一致
String NmaeISO88591 = java.net.URLDecoder.decode(name, "ISO-8859-1");
System.out.println("NameUTF8= "+NameUTF8);
System.out.println("NmaeISO88591="+NmaeISO88591);
System.out.println(name);
System.out.println(java.net.URLDecoder.decode(name, "UTF-8"));
输出为:
%E6%B5%8B%E8%AF%95
%25E6%25B5%258B%25E8%25AF%2595
NameUTF8= %E6%B5%8B%E8%AF%95
NmaeISO88591=%E6%B5%8B%E8%AF%95 (NameUTF8与NmaeISO88591结果是一致的)
%25E6%25B5%258B%25E8%25AF%2595
%E6%B5%8B%E8%AF%95
第一次编码后将汉字编码为%和字母数字的格式,而第二次编码的时候是对%字母数字进行编码,虽然解码的时候使用的是ISO-8859-1,但是对于%和字母数字而言用ISO-8859-1和UTF-8解码出来的是一样的,此时就回到了汉字被编码过一次的字符串了,当再次进行解码的时候使用UTF-8就回将它转会汉字。