get请求中文传参乱码问题解决汇总终极版

get请求中文传参乱码问题解决汇总终极版

一、如果使用tomcat作为服务器,那么修改tomcat配置文件conf/server.xml中,在 中加入 URIEncoding=”utf-8”的编码集
此方式需改变服务器配置,且当更换服务器时需重新配置。不推荐。
二、后台接收参数时,需处理String str = new String (request. getParameter (“param”). getBytes(“iso8859-1”),”UTF-8”);因为服务器默认会对get请求进行iso8859-1编码,所以直接采用iso8859-1解码后再进行utf-8编码。
此方法要求浏览器编码格式 同样不推荐。
三、在传入参数时对参数进行两次编码

URLEncoder.encode(URLEncoder.encode(param,"UTF-8"),"UTF-8"))

服务端获取参数时进行一次解码

 String param= URLDecoder.decode(param, "UTF-8");

传参两次编码的原因是在后台接收参数时候,首先通过request.getParameter()自动进行第一次解码。
传参时第一次编码得到的是UTF-8形式的URL,第二次编码得到的依然是UTF-8形式的URL,但是在效果上相当于首先进行了一 次UTF-8编码再进行了一次UTF-8编码,因为第一次编码后参数已变成英文字符,对英文字符来说UTF-8编码和ISO- 8859-1编码的效果相同。所以两次编码后服务器无论默认什么解码方式解码后都是我们第一次的utf-8编码后的结果。后台按一次utf-8解码,成功!
注意:有时一个参数进行了多次请求传递可能需要2次以上的编码

你可能感兴趣的:(java)