关闭

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

标签: tomcatjavaweb乱码utf-8GBK
1694人阅读 评论(0) 收藏 举报
分类:
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]);
   }
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:20325次
    • 积分:314
    • 等级:
    • 排名:千里之外
    • 原创:7篇
    • 转载:25篇
    • 译文:0篇
    • 评论:3条
    文章分类
    最新评论