原文档:HttpServlet中文乱码问题


客户端提交数据给服务器端(Requset)

如果数据中带有中文的话,有可能会出现乱码情况,那么可以参照以下方法解决。

如果是GET方式

  1. 代码转码
  1. String username = request.getParameter("username");
  2. String password = request.getParameter("password");
  3. System.out.println("userName="+username+"==password="+password);
  4. //get请求过来的数据,在url地址栏上就已经经过编码了,所以我们取到的就是乱码,
  5. //tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码
  6. //先让文字回到ISO-8859-1对应的字节数组 , 然后再按utf-8组拼字符串
  7. username = new String(username.getBytes("ISO-8859-1") , "UTF-8");
  8. System.out.println("userName="+username+"==password="+password);
  1. 直接在tomcat里面做配置,以后get请求过来的数据永远都是用UTF-8编码。

可以在tomcat里面做设置处理 conf/server.xml 加上URIEncoding=”utf-8”

如果是POST方式

这个说的是设置请求体里面的文字编码。 get方式,用这行,有用吗? —-> 没用,因为Get表单提交的内容在地址栏

  1. request.setCharacterEncoding("UTF-8");

这行设置一定要写在getParameter之前。

响应的数据中有中文(Response)

那么有可能出现中文乱码

以字符流输出

response.getWriter()

  1. //1. 指定输出到客户端的时候,这些文字使用UTF-8编码
  2. response.setCharacterEncoding("UTF-8");
  3. //2. 直接规定浏览器看这份数据的时候,使用什么编码来看。
  4. response.setHeader("Content-Type", "text/html; charset=UTF-8");
  5. response.getWriter().write("Hello 世界...");

以字节流输出

response.getOutputStream()

  1. //1. 指定浏览器看这份数据使用的码表
  2. response.setHeader("Content-Type", "text/html;charset=UTF-8");
  3. //2. 指定输出的中文用的码表
  4. response.getOutputStream().write("你好 World".getBytes("UTF-8"));

不管是字节流还是字符流,直接使用一行代码就可以了。

  1. response.setContentType("text/html;charset=UTF-8");

然后在写数据即可。