关于Servlet的PrintWriter 中文乱码问题

时间:2020-12-01 07:01:55

ps:servlet的PrintWriter和ServletOutputStream是不能同时使用的,同时使用会抛异常;

PrintWriter是字符流.ServletOutputStream是字节流.字节流是万金油,所以这里说的是当使用字符流PrintWriter的时候;

如下代码:

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String data = "中国";
response.getWriter().write(data);
}

向浏览器输出中国两字;很愉快的发布之后,浏览器返回的是??.

是因为:

1; 当服务器去调用servlet的时候同时创建了一个resquest和一个response对象.resquest用来存储客户端发送请求,response用来存储服务器返回的数据;

2: 当Servlet拿着data去查它的默认码表,Sun公司显然是查国外的码表:ISO8859-1之类的...查完码表将它存储在response里,然后输出在浏览器里,浏览器的编码在中文的windows下一般是gbk或者gb2312.浏览器拿到ios编码的字符再查gbk的码表,显然就是乱码了.

解决:既然是Servlet里出的问题,那么就修改它的编码方式:

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String data = "中国";
response.setCharacterEncoding("UTF-8");//一般我们将字符编码设置成UTF-8.国际标准.
response.getWriter().write(data); }

这个时候部署上去看见三个字:涓浗,是因为我们的浏览器的编码是GBK(默认),所以我们要告知浏览器的编码方式(当然你也可以自己在浏览器里设置,不推荐:让用户自己去操作的都是不良好的用户体验;

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setHeader("Content-type", "text/html;charset=UTF-8");//告知浏览器编码方式;
String data = "中国";
response.setCharacterEncoding("UTF-8");
response.getWriter().write(data); }

这样我们就能看见"中国"啦~