tomcat编码配置gbk_tomcat为utf8编码,解析gbk编码的URL请求,中文乱码处理

当Tomcat设置为UTF-8解码,接收GBK编码的URL请求会导致中文乱码。解决方案是通过`request.getQueryString()`获取原始编码并进行URL解码,再转换为GBK,从而正确处理中文参数。给出的HttpRequestReader类实现了自定义解析HTTP请求参数以解决乱码问题。
摘要由CSDN通过智能技术生成

项目中tomcat设置为utf8解码,当对外的url接口(如ReceiveAction)接收到gbk编码请求时候会自动被tomcat解码为utf8,

此时中文直接request.getParameter("content")出来就是乱码,无法直接转换回gbk,怎么转换都是乱码。

解决方法:通过requset.getQueryString() 来获取到 %D6%D0%B9%FA 再urldecode 下就得到了 正确的中文了

此类,就是基于通过自己解析http的queryString和postdata来处理乱码问题的

import java.io.IOException;

import java.util.ArrayList;

import java.util.Enumeration;

import java.util.Hashtable;

import java.util.StringTokenizer;

import javax.servlet.http.HttpServletRequest;

/**

* 项目中tomcat设置为utf8解码,当对外的url接口(如ReceiveAction)接收到gbk编码请求时候会自动被tomcat解码为utf8,

* 此时中文直接request.getParameter("content")出来就是乱码,无法直接转换回gbk,怎么转换都是乱码。

*

* 解决方法:通过requset.getQueryString() 来获取到 %D6%D0%B9%FA 再urldecode 下就得到了 正确的中文了

* 此类,就是基于通过自己解析http的queryString和postdata来处理乱码问题的

*

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值