JSP(J2EE)中文乱码

常见的解决方式如修改tomcat,配置request编码方式等在这里就不说了,网络上很多。这里提到一种比较少见的一种情况,但也常被忽略的情况。

通常情况下我们配置request编码会在web.xml配置个spring的过滤器,如下:

<filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>

这里的配置没问题,问题会出现在正面的mapping里:

<filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

通常情况下很多人不会留意这个mapping放的位置,其实所有的filter-mapping执行是有先后有顺序的,如果在这个encodingFilter的mapping前放上spring的dispatcherFilter的mapping,那就会是出现先处理完springmvc请求后再修改request的编码方式,但这时已经太迟了,乱码都已经提交到业务层去了。

因为必须将这个encodingFilter的mapping放在所有的filter-mapping前面,即先指定完编码后再处理其他事务。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值