tomcat为utf8编码,解析gbk编码的URL请求,中文乱码处理
项目中tomcat设置为utf8解码,当对外的url接口(如ReceiveAction)接收到gbk编码请求时候会自动被tomcat解码为utf8,
此时中文直接request.getParameter("content")出来就是乱码,无法直接转换回gbk,怎么转换都是乱码。
解决方法:通过requset.getQueryString() 来获取到 %D6%D0%B9%FA 再urldecode 下就得到了 正确的中文了
例:
URL:http://127.0.0.1:8080/ValueAddPlane/clc/notify?orderstate=2&portorderid=2015101510449194&tickets=%c6%eb%c4%cb%ca%a2%2c7848501352120
参数中tickets为“齐乃盛,2c7848501352120”
controller中处理
String reqStr = request.getQueryString(); //得到的字符串是 “orderstate=2&portorderid=2015101510449194&tickets=齐乃盛,2c7848501352120“
String decodeReqStr = URLDecoder.decode(reqStr, "GBK");
String[] reqArry = decodeReqStr.split("&");
Map<String, String> reqMap = new HashMap<String, String>();
for (String reqItem : reqArry) {
String[] reqItemArray = reqItem.split("=");
reqMap.put(reqItemArray[0], reqItemArray[1]);
}