解决乱码有个原则:解码和编码必须是同一码表!如果从页面中(如:html中)提交内容,提交的内容编码依页面使用的编码而定。
1.服务器:
1>get提交方式 get提交方式当提交到tomca服务器会立刻被解码,tomcat默认解码方式为ISO-8859-1,所以出现乱码。因为到达服务器就已经出现乱码了,我们只有拿着乱码去重新编码一次,这样就能还原到解码前的编码了,然后拿着这个编码找到对应的码表去解码,这样就不会乱码了。代码如下:
浏览器提交参数
解决服务器端解码
public class CServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String name = request.getParameter("name");
//1 将错误的结果编码回字节数组
byte[] bytes = name.getBytes("ISO-8859-1");
//2 将字节数组使用正确的码表解码回正确的中文
String name2 = new String(bytes,"UTF-8");
System.out.println("name2=" + name2);
}
}
2>post提交方式 post提交数据到服务端时请求体的部分不分立刻被解码,只有调用了获取参数相应的方法(例如:getParameter("name")方法)才会去解码。所以我们解决方式可以有两种:
第一种:和上面get方式一样,先获取提交的值然后编码,再拿着乱码的结果重新解码一次就可以了。
第二种:在调用获取参数的方法前设置相应的解码码表,然后再获取参数。代码如下:
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//在调用getParameter方法之前先设置解码码表
request.setCharacterEncoding("UTF-8");
//post方式提交的内容,在调用getParameter方法时才会解码
String name = request.getParameter("name");
System.out.println(name);
}
2.浏览器:
先要弄清楚3点:
1)明确响应给浏览器使用什么编码setCharacterEncoding方法;
2)还要告诉浏览器用什么编码解码setContentType方法;
3)以上1、2点中的编码必须要一致。
参考以下代码:
public class CServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setCharacterEncoding("UTF-8");
//或者只写这一句也可以,服务器会跟据参数中“;”前的类型来判断然后自动设置响应编码
response.setContentType("text/html;charset=utf-8");
response.getWriter().write("你好!".toCharArray());
}
}