本机、生产环境Tomcat乱码处理

项目由很多模块构成,且每个人负责自己的模块,并且由于历史原因,很多共通配置级的文件没有权限调整,因此不能照搬Tomcat全UTF-8配置的指南。

问题:
1,本地开发环境,[color=red]只有Connector中的参数URIEncoding和UseBodyEncoding能影响HttpGet方式的编码[/color],但是生产环境中,可以通过Filter修改。
[list]
[*]1.1 由于生产环境是Apache+Tomcat使用mod_jk来做负载,因此Connector使用了AJP/1.3协议,猜测由于协议不同导致的(HTTP/1.1 & AJP/1.3),调试,找原因,排除
[*]1.2,后来发现是生产环境Forward引起的,Forward前的参数解码参照的是Forward前项目的相关环境,而Forward后环境只影响HTTP GET方式提交的QueryString部分参数的解码【此时通过Filter设置的请求参数会影响到QueryString的解码,这与Forward前QueryString请求参数的解码是不同的】,POST提交的参数的解码只受Forward前环境的影响,
[*]1.3,从request第一次取值是会进行解码操作,通过在HttpServletRequest的相应方法中设置断点找到什么时候进行第一次解码
[/list]
2,生产环境下,[color=red]只有forward之前的上下文环境能影响POST提交参数的解码[/color],forward之后的项目环境没有机会影响到(forward后,ApplicationHttpRequest的parsed是false,而内部参数RequestFacade的parsed是true【对应就是CoyoteRequest中的parsed是true】)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值