关于servlet的PrintWrite中文乱码的解决办法

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);
            
    }

复制代码

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

你可能感兴趣的:(java,web)