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