今天做项目,做到页面跳转去request参数
发现中文参数是乱码,于是上网查了相关资料:
http://hpfgc.blog.163.com/blog/static/147995572009111462947544/
http://blog.sina.com.cn/s/blog_632bb1950100l77z.html
http请求是以ISO-8859-1的编码来传送url的,如果页面的content-type为utf-8,那么在发送请求时,会将字符转成utf-8后进行传送。
这样服务器收到字节流后,将它转成相应的字符,request.getParameter("xx")直接得到了字符串,从字节流到字符流的转换系统帮我们做了(错误来源)
解决方案:
1. 没有编码的URL
HTML页面:
var url = "./SuggestServlet?tagName="+document.getElementById('tagName').value;
在使用java方法取参数时
String myparam = request.getParameter("tagName"); //得到的是一个乱码字符串 request.getCharacterEncoding(); //得到的是一个null值tomcat默认的是ISO-8859-1编码解析,这就是我们得到乱码的原因了。
myparam = new String(myparam.getBytes("ISO-8859-1"),"UTF-8"); 这样就能得到中文了,后面的根据charset的声明来该,如果是GBK,就改成相应的就可以了。
2. 使用javascript的encodeURI编码中文参数
HTML页面:
var url = "./SuggestServlet?tagName="+encodeURI(document.getElementById('tagName').value);
String myparam = request.getParameter("tagName"); //得到的是UTF-8编码之后的字符串,不是乱码
String decodingParam = URLDecoder.decode(myparam, "UTF-8");
在java中导入相应的类:
java.net.URLDecoder
java.net.URLEncoder
另外!!
在对后台java程序赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页面上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用 xx=java.net.URLDecoder.decode(xx,"UTF-8");/*需要处理异常*/进行一次解码就好了。
var url = "./SuggestServlet?tagName="+encodeURI(encodeURI(document.getElementById('tagName').value));