ps:servlet的PrintWriter和ServletOutputStream是不能同时使用的,同时使用会抛异常;html
PrintWriter是字符流.ServletOutputStream是字节流.字节流是万金油,因此这里说的是当使用字符流PrintWriter的时候;ios
以下代码:windows
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的码表,显然就是乱码了.spa
解决:既然是Servlet里出的问题,那么就修改它的编码方式:code
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String data = "中国"; response.setCharacterEncoding("UTF-8");//通常咱们将字符编码设置成UTF-8.国际标准. response.getWriter().write(data); }
这个时候部署上去看见三个字:涓浗,是由于咱们的浏览器的编码是GBK(默认),因此咱们要告知浏览器的编码方式(固然你也能够本身在浏览器里设置,不推荐:让用户本身去操做的都是不良好的用户体验;htm
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); }
这样咱们就能看见"中国"啦~对象