bluedot的专栏

daydayup

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

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]);
   }
阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭