tomcat设置为UTF-8,解析GBK编码的UTL请求,中文乱码处理

时间:2023-01-05 10:28:19
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]);    }