request.getParameter()在get和post方法中文乱码问题

乱码原因:Http请求传输时将url以ISO-8859-1编码,服务器收到字节流后默认会以ISO-8859-1编码来解码成字符流(造成中文乱码)

post请求:

假设提交请求的jsp页面是UTF-8编码

<%@ page language="Java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>

解决方法1:在服务端获取参数前,先设置解码方式。

//设置解码方式,对于简体中文,使用UTF-8解码  
request.setCharacterEncoding("UTF-8");  
request.getParameter("参数名");  

解决方法2:Tomcat默认编码ISO8859-1,设置成其他的编码

<Connector port="8080" protocol="HTTP/1.1"     
    connectionTimeout="20000"     
    redirectPort="8444"     
    useBodyEncodingForURI="true" URIEncoding="UTF-8"/>   

重点在 userBodyEncodingForURI 和 URIEncoding 这两个属性

下面来解释一下这两个属性的意义

useBodyEncodingForURI参数表示是否用request.setCharacterEncoding参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false。

URIEncoding参数指定对所有GET方式请求进行统一的重新编码(解码)的编码。

URIEncoding和useBodyEncodingForURI区别是,

URIEncoding是对所有GET方式的请求的数据进行统一的重新编码,

而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码,不同的页面可以有不同的重新编码的编码

解决方法3:通过字符串和字节流转换时使用正确的编码获取中文参数

String str = new String(request.getParameter("参数名").getBytes("iso-8859-1"), "utf-8"); 

get请求:

对于get请求,上面针对于post的请求的三种解决方法,只有第三种可以用,第一种和第二种并没有效果,这和tomcat的内部机制有关。
对于get请求,还有一个很笨拙的方法,不推荐使用,贴出来,以供了解:

/获取请求里包含的查询字符串  
String rawQueryStr = request.getQueryString();  
out.println("原始查询字符串为:" + rawQueryStr + "<hr/>");  
//使用URLDecoder解码字符串  
String queryStr = java.net.URLDecoder.decode(  
    rawQueryStr , "gbk");  
out.println("解码后的查询字符串为:" + queryStr + "<hr/>");  
//以&符号分解查询字符串  
String[] paramPairs = queryStr.split("&");  
for(String paramPair : paramPairs)  
{  
    out.println("每个请求参数名、值对为:" + paramPair + "<br/>");  
    //以=来分解请求参数名和值  
    String[] nameValue = paramPair.split("=");  
    out.println(nameValue[0] + "参数的值是:" +   
        nameValue[1]+ "<hr/>");  
}  

 

posted @ 2017-07-17 21:14  门罗的魔术师  阅读(833)  评论(0编辑  收藏  举报