1.问题:线上之前没有乱码问题,自从升级了一个运维管理服务abc之后 tomcat web就有了请求乱码
2.原因:应用中需要配置一个运维管理服务filter,简称abcFilter。该服务升级之后有request.getParameter方法,
而应用web.xml中CharacterEncodingFilter这个filter没有放在第一位
刚好abcFilter在CharacterEncodingFilter之前,使用了getParameter();
这里有个陷阱,整个web应用里,这个filter的拦截顺序必须是第一个,否则还是会出现乱码问题。这是因为(至少在tomcat里):
request对象的parameter并不是一开始就解析的,它是等你第一次调用getParameter*等凡和获得请求参数有关的方法的时候才解析的
paramter一旦被解析过一次,那就不会再次被解析。所以如果在CharacterEncodingFilter之前有另外一个filter,而这个filter调用了getParameter*方法,
那么就有可能使用错误的encoding来解析,从而造成乱码问题。
3:解决方法:
<filter> <filter-name>characterEncodingFilter</filter-name> <display-name>Character Encoding Filter</display-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>