
使用javascript编码不给浏览器插手的机会,编码之后再向服务器发送请求,然后在服务器中解码。在掌握该方法的时候,Javascript编码的三个方法:escape()、encodeURI()、encodeURIComponent()
参照乱码解决2
一般地,我们都会在jsp文件的开头加上这样的声明:
产生乱码的原因一句话就能说明白:
比如说在后端把字符串 "你好,世界" 按照 UTF-8 进行编码,但是前端却按照 GB2312 进行解码,那自然会产生乱码。
因为目前大部分浏览器都是采用 UTF-8 编码的,所以向浏览器输出中文字符,只需在 doGet 方法中指定 Content-Type:text/htmlcharset=utf-8。
获取 HTTP 请求中的中文参数时可能会有乱码,所以先将字符串变回字节数组,然后再按照 UTF-8 进行编码。假设 HTTP 请求中带了一个 username 的参数,那么就需要在 doGet 方法中进行如下处理
问题是,在实际的应用场景中 HTTP 请求携带的参数可能有多个,所以就不能只针对某个参数进行修改。解决的方案是使用装饰器模式,写一个 HttpServletRequest 的装饰器类,经过装饰的 request 对请求中的任何参数都能进行编码的处理。
然后用一个 Filter 对所有的请求进行编码的处理,然后再把处理过后的 request 对象传递给 Servlet:
因为大多数情况下我们在 doPost 方法内都会调用 doGet 方法,因此按照上面的做法就能解决 POST 请求中的中文乱码问题。如果使用 Spring 进行开发,那么有 POST 请求乱码的专门解决方案。在 web.xml 中添加如下配置:
这样就可以解决 POST 的乱码问题了。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)