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"); //这一句必须放在输出语句之前
本文详细介绍了在Java Web开发中遇到的中文乱码问题及其解决方案。主要针对使用response.getOutputStream()和response.getWriter()方法输出中文时出现的问题,提出了设置字符编码和响应头的方法来解决乱码。
3504

被折叠的 条评论
为什么被折叠?



