JavaWeb response使用中造成的中文乱码问题解决

一、乱码原因

当我们使用response.getWriter().write();方法向浏览器中写入数据时,经常会出现中文乱码问题。首先我们要去了解一下关于response的write方法,write方法是将内容写入response缓冲区之中。而在缓冲区中所使用的编码是 ISO8859-1,这种编码方式是不支持中文的,所以无法识别我们所写入的中文信息。为了避免乱码问题,我们要是用 UTF-8 的编码方法

二、解决方法

第一步:首先我们要更改缓冲区中所使用的编码方式为 UTF-8.

写入一条数据来测试

//设置缓冲区中使用的编码为UTF-8
  response.setCharacterEncoding("UTF-8");
  response.getWriter().write("中文乱码怎么办");

此时我们运行程序发现中文乱码问题并没有解决
在这里插入图片描述
这是因为,虽然缓冲区中使用了UTF-8的编码方式但是浏览器解析缓冲区中的内容时使用的确不是 UTF-8的编码方式。我们可以在eclipse中右键查看默认浏览器使用的编码方式
在这里插入图片描述
可以看到浏览器使用的默认编码方式是GB2312,所以中文乱码任然存在。

此时如果我们将浏览器的默认编码方式改为 UTF-8 ,发现问题得到了解决。
所以光设置缓冲区所使用的编码方式是不够的。

在这里插入图片描述

第二步:设置浏览器接收内容时所使用的编码方式为UTF-8

写入代码

  //设置缓冲区中使用的编码为UTF-8
  response.setCharacterEncoding("UTF-8");
  //设置l浏览器接受内容时所使用的编码方式
  response.setContentType("text/html;charset = UTF-8");
  response.getWriter().write("中文乱码怎么办");

此时我们可以看到问题完美解决

在这里插入图片描述

三、注意事项

1. 因为设置了浏览器的编码方式,缓冲区的编码方式也会被自动设置,所以我们只需要设置浏览器的编码方式就可以解决问题

 //设置l浏览器接受内容时所使用的编码方式
 response.setContentType("text/html;charset = UTF-8");

2. 设置编码方式一定要写在响应体之前,也就是写在写入内容之前

发布了26 篇原创文章 · 获赞 24 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/showadwalker/article/details/83958129