1、采用 response.getOutputStream().write("中国".getBytes("utf-8")) 输出,乱码问题,原因是此方法输出的是字节流,采用的是utf-8,如果输出时的码表和浏览器打开所用的码表不同,就有乱码问题,浏览器默认用平台码(所在操作系统环境决定)打开。
解决方案:设置响应头:response.setHeader("Content-Type", "text/html;charset=utf-8");明确的指定浏览器打开的方式。
2、response.getWriter().write("中国");在网络中不能真的传输字符,传入此方法的字符最终也要查码表转为字节,服务器默认查ISO8859-1,而此码表中没有中文于是用了?替代,所以浏览器拿到的其实是两个? 。
解决方案:通过response.setCharacterEncoding("utf-8");明确指定服务器将response中的内容转为字节时采用的码表
设置响应头:response.setHeader("Content-Type", "text/html;charset=utf-8");明确的指定浏览器打开的方式。
上面两个乱码问题其实可以通过一行代码就可以处理,加上:
response.setContentType( "text/html;charset=utf-8"); //这一句必须放在输出语句之前