Servlet处理中文乱码问题(请求/响应)
Posted 星空异皓`
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Servlet处理中文乱码问题(请求/响应)相关的知识,希望对你有一定的参考价值。
乱码原因
传输方和接收方采用的编码不一致。传输方对参数采用的是UTF-8编码而接收方却用GBK进行解析,当然是乱码。 Tomcat服务器默认采用的ISO8859-1编码得到参数值。虽然①中采用了同样的编码方式,但经过tomcat一处理,也会出现乱码(GET方式)
1、请求中文乱码的处理:
--post
request.setCharacterEncoding("UTF-8");
--get
String name = new String(“中国”.getBytes(“iso-8859-1”),“UTF-8”)
2、响应中文乱码的处理:
--①字节流:
设置浏览器默认打开的编码:
resposne.setHeader(“Content-Type”,”text/html;charset=UTF-8”);
设置中文字节取出的时候编码.
“中文”.getBytes(“UTF-8”);
--② 字符流:
设置浏览器打开的时候的编码
resposne.setHeader(“Content-Type”,”text/html;charset=UTF-8”);
设置response的缓冲区的编码
response.setCharacterEncoding(“UTF-8”);
**简化的写法
response.setContentType(“text/html;charset=UTF-8”);
以上是关于Servlet处理中文乱码问题(请求/响应)的主要内容,如果未能解决你的问题,请参考以下文章