request和response中文乱码问题后台处理办法
request接收参数的中文乱码的处理:
GET:
方法一:使用String的构造方法:
new String(request.getParameter("传过来的name").getBytes("ISO-8859-1"), "UTF-8");
方法二:修改tomcat7的默认编码方式,server.xml中端口号那项添加配置:
<Connector connectionTimeout="50000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
POST:
方法一:设置request的缓冲区的编码:
request.setCharacterEncoding("UTF-8");
方法二:使用spring的编码过滤器,在web.xml中添加:
<filter> <filter-name>CharacterEncodingfilter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class> <init-param> <param-name>encodingparam-name> <param-value>UTF-8param-value> init-param> <init-param> <param-name>forceEncodingparam-name> <param-value>trueparam-value> init-param> filter> <filter-mapping> <filter-name>CharacterEncodingfilter-name> <url-pattern>/*url-pattern> filter-mapping>
response输出中文的乱码问题:
字符流输出中文:
方法一:
// 设置浏览器字符集编码. response.setHeader("Content-Type","text/html;charset=UTF-8"); // 设置response的缓冲区的编码. response.setCharacterEncoding("UTF-8");
方法二:建议使用:
response.setContentType("text/html;charset=UTF-8");
字节流输出中文:(实际中不会用)
// 使用字节流的方式输出中文: ServletOutputStream outputStream = response.getOutputStream(); // 设置浏览器默认打开的时候采用的字符集 response.setHeader("Content-Type", "text/html;charset=UTF-8"); // 设置中文转成字节数组字符集编码 outputStream.write("中文".getBytes("UTF-8"));
说一下,tomcat8开始默认字符集是utf-8