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/>"); }