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); }
这样我们就能看见"中国"啦~