本机、生产环境Tomcat乱码处理
项目由很多模块构成,且每个人负责自己的模块,并且由于历史原因,很多共通配置级的文件没有权限调整,因此不能照搬Tomcat全UTF-8配置的指南。
问题:
1,本地开发环境,只有Connector中的参数URIEncoding和UseBodyEncoding能影响HttpGet方式的编码,但是生产环境中,可以通过Filter修改。
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的相应方法中设置断点找到什么时候进行第一次解码
2,生产环境下,只有forward之前的上下文环境能影响POST提交参数的解码,forward之后的项目环境没有机会影响到(forward后,ApplicationHttpRequest的parsed是false,而内部参数RequestFacade的parsed是true【对应就是CoyoteRequest中的parsed是true】)