web.xml 文件中一般包括 servlet, spring, filter, listenr的配置。那么他们是按照一个什么顺序加载呢?
加载顺序会影响对spring bean 的调用。
??? 比如filter 需要用到 bean ,但是加载顺序是 先加载filter 后加载spring,则filter中初始化操作中的bean为null;
首先可以肯定 加载顺序与他们在web.xml 文件中的先后顺序无关。
web.xml 中 listener 和 serverlet 的加载顺序为 先 listener 后serverlet
最终得出结果:先 listener >> filter >> servlet >> spring
所以,如果过滤器中要使用到 bean,可以将spring 的加载 改成 Listener的方式
<listener>
??????? <listener-class>
??????????? org.springframework.web.context.ContextLoaderListener
??????? </listener-class>
??? </listener>
搞定!
关于他们的内部执行顺序,也需要注意,如下面文章中遇到的问题
web.xml的filter执行顺序导致的乱码,切记!
2008-05-02 01:38
发现引起bug的原因是web.xml的下面几行:
??? <filter-mapping>
??????? <filter-name>SecurityFilter</filter-name>
??????? <url-pattern>*.do</url-pattern>
??? </filter-mapping>
??? <filter-mapping>
??????? <filter-name>CharacterEncoding</filter-name>
??????? <url-pattern>*.do</url-pattern>
??? </filter-mapping>
??? <filter-mapping>
??????? <filter-name>CharacterEncoding</filter-name>
??????? <url-pattern>*.jsp</url-pattern>
??? </filter-mapping>
根据servlet2.3规范filter执行是按照web.xml配置的filter-mapping先后顺序进行执行,所以上面的配置会导致遇见*.do的url请求,先进行SecurityFilter的过滤器处理,这时候没有做编码处理,已经是乱码,到下面的filter处理时已经时乱码,再做编码处理已经没有用处。
修正方式,调整filter-mapping顺序,如下:
??? <filter-mapping>
??????? <filter-name>CharacterEncoding</filter-name>
??????? <url-pattern>*.do</url-pattern>
??? </filter-mapping>
??? <filter-mapping>
??????? <filter-name>CharacterEncoding</filter-name>
??????? <url-pattern>*.jsp</url-pattern>
??? </filter-mapping>
??? <filter-mapping>
??????? <filter-name>SecurityFilter</filter-name>
??????? <url-pattern>*.do</url-pattern>
??? </filter-mapping>