关于B/S模式的web服务交互过程中的中文乱码问题浅析
Web服务是服务端和浏览器之间的交互,两者之间因为中文编码的问题很容易导致乱码出现。
站在服务端(servlet)角度,乱码分成两种接收请求(request)和响应浏览器(response)。
有关乱码的问题主要是下图中的四个组件之间的引起的。
(1)request请求产生的乱码:
乱码产生的大概原理:
解决思路就是:IE浏览器和request的编码方式要一致。
因为request请求有两种常见的提交方式:get和post请求,这两种方式处理乱码的方式也不相同。
get请求的解决方法(a标签提交):
String name = request.getParameter("name"); name = new String(name.getBytes("ISO-8859-1"), "utf-8"); |
或者在tomcat的server.xml文件中:
修改tomcat的配置文件server.xml: 只需增加 URIEncoding="UTF-8" 这一句,然后重启tomcat即可。 |
Post请求方式解决方法:
request.setCharacterEncoding("utf-8");
(2)response请求产生的乱码:
乱码产生的大概原理:
解决思路:设置response对象和浏览器的编码方式一致
设置response的编码方式:
response.setCharacterEncoding("utf-8"); |
设置浏览器的编码方式是:
response.setHeader("content-type", "text/html;charset=utf-8"); |
一般经常使用(共同设置response和浏览器的编码方式):
response.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=utf-8"); |