使用response给客户端返回中文信息时如果不做编码处理很容易出现乱码的现象。因此我们需要使用response提供的方法来解决这个问题
下面举个例子来看看处理过程
编写以下代码
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
PrintWriter writer = response.getWriter();
writer.write("你好");
}
启动Tomcat,然后执行该servlet
发现并没有输出你好.而是两个??
原因是因为resonse响应体的默认编码是iso8859-1,这个编码没有中文编码所以是"??",因此要解决这个问题,就需要设置响应体的编码.
使用setCharacterEncoding(String)设置响应体编码
我们常用的带有中文的编码是UTF-8
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setCharacterEncoding("UTF-8");
PrintWriter writer = response.getWriter();
writer.write("你好");
}
再次执行此servlet
发现还是没有输出正确的中文.
–>原因,response的响应体编码修改回来了,但是浏览器的编码并不是UTF-8,谷歌浏览器默认编码是GBK.要解决浏览器这个问题有两个办法.
1,在浏览器手动设置编码,但大多数用户并不会这步
2,设置响应头告诉浏览器使用UTF-8编码
我们使用第二种方法
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//告诉浏览器使用UTF-8编码
response.setContentType("text/html;charset=UTF-8");
PrintWriter writer = response.getWriter();
writer.write("你好");
}
再次执行
能够正常的输出"你好".
在观察上面的代码,我只写了 response.setContentType(“text/html;charset=UTF-8”);并没有写response.setCharacterEncoding(“UTF-8”);
原因setContentType已经包含了setCharacterEncoding的功能。
所以在实际编码中只需要编写response.setContentType(“text/html;charset=UTF-8”);就可以了
总结:
1,当response响应体含中文时,使用response.setContentType(“text/html;charset=UTF-8”);就能解决中文乱码的问题