Servlet中文乱码解析
一:response输出有两种方式,一种是字符流输出 即response.getWriter()的write()方法,另一种是字节流输出 即response.getOutputStream()的write方法,如果用字节流输出的话,只需要设置浏览器的响应头 即浏览器的打开格式和编码格式:
如response.setHeader(“text/html”,”chartset=”UTF-8”)也可以用meta标签来设置浏览器的打开格
一种方法
式和编码格式。<meta HTTP-EQUIV='content-type' CONTENT='text/html;charset=UTF-8'>
/response.setContentType("text/html;charset=UTF-8");//利用response来设置打开浏览器的另
如果是按字符流输出 不仅设置浏览器的响应头 还需要设置response对象的编码格式response.setCharacterEncoding("UTF-8");方法.如果不设置就会出现中文乱码现象
二:
Request 获取对象中文乱码问题。
因为浏览器对中文默认查询的是gb2312码表,然后将查询值返回给web服务器,服务器再保存至到Request对象中,不过因为这里查询的是ISO8859-1码表,所以对应的String对象是乱码,所以Request.getParameter(),得到的也是乱码,解决问题:需要设置request查询的码表格式,即: request.setCharacterEncoding("UTF-8"). 也可以是gb2312或gbk方式,不过也要设置下浏览器的打开方式和编码格式且与request查询的编码格式相同即可,