首页 > 代码库 > Servlet处理中文乱码问题(请求/响应)

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处理中文乱码问题(请求/响应)