1、原始Servlet开发中使用Filter
最早Servlet开发中要想使用过滤器需要在web.xml中做如下配置:
<filter>
<filter-name>Image Filter</filter-name>
<filter-class>com.acme.ImageServlet</filter-class>
</filter>
<filter-mapping>
<filter-name>Logging Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2、原始配置方式有什么问题?
1、无法将Spring管理的Bean注册为Filter
2、每增加一个Filter都需要在web.xml中配置(例如实现 SpringSecurity,SpringMVC->dispatchServlet 需要非常多 Filter)
3、如何解决这些问题呢?
1、解决Spring管理Bean的问题
通常情况下web容器启动时Spring容器还没产生,根本不可能将Spring中的Bean拿出来使用,那么 DelegatingFilterProxy 就能很好解决这个问题了。
什么是 DelegatingFilterProxy:DelegatingFilterProxy 是一个特殊的Filter,它在web容器启动时作为一个Filter注册到ServletContext,
处理请求时 DelegatingFilterProxy 再从Spring中取出它所代理的FilterBean来执行Filter逻辑
因此,每一个 DelegatingFilterProxy 都有一个 targetFilter。随之也带来了另外一个问题,那就是 DelegatingFilterProxy 过多。
2、解决频繁配置的问题
首先想到的就是如果一个 DelegatingFilterProxy 能处理多个Filter就能解决了,因此引入了 FilterChainProxy,
将多个Filter链包装在 FilterChainProxy 中,然后再将 FilterChainProxy 交由 DelegatingFilterProxy 代理就完美解决了 DelegatingFilterProxy 过多的问题。
4、总结
1、传统配置下,请求处理:
2、引入DelegatingFilterProxy后请求处理:
3、引入FilterChainProxy后请求处理:
FilterChainProxy | FilterChainProxy处理 |
---|---|
![]() | ![]() |