请求参数编码处理的一点注意事项

请求参数编码处理的一点注意事项


注意

request.setCharacterEncoding(charset)必须写在第一次使用request.getParameter()之前, 这样才能保证参数是按照已经设置的字符编码来获取.

response.setCharacterEncoding(charset)必须写在PrintWriter out = response.getWriter()之前, 这样才能out按照已经设置的字符编码来进行字符输出.

更优方法

通过过滤器, 我们可以保证在Servlet或JSP执行之前就设置好了请求和响应的字符编码.


另外注意GET请求参数编码处理

在HttpServletRequest的API文档中, 对setCharacterEncoding()的说明很清楚:

Overrides thename of the character encoding used in body of this request.

也就是说, 这个方法对于请求Body中的字符编码才有作用, 也就是基本上这个方法只对Post产生作用, 当请求使用Get发出时, 则没有定义这个方法是否会影响Web容器处理编码的方式(究其原因,是因为处理URL的是Http服务器,而非Web容器).

若使用Tomcat并采用GET, 或没有设置setCharacterEncoding(), 且已取得一个请求参数字符串, 另外一个处理编码的方式, 则是通过String的getByte()指定编码来取得该字符串的字节数组, 然后再重新构造为正确编码的字符串.

例如, 若Browser使用UTF8处理字符, Web容器默认使用ISO-8859-1编码, 则正确处理编码的方式为:

String name = request.getParameter("name");

name = new String(name.getBytes("ISO-8859-1"),"UTF-8");


记于

Jan 4th, 2016
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章