1.Filter的定义。
- Filter是过滤器
- Filter可以在Servlet这个目标程序执行之前添加代码,也可以在目标Servlet执行之后添加代码,之前之后都可以添加过滤规则。
- 一般情况下,在过滤器中编写公共代码
2.编写过滤器
- 第一步,编写一个Java类实现一个接口
jarkata.servlet.Filter
,并实现此接口的方法。
init方法: 在Filter对象第一次被创建之后调用,并且只调用一次
doFilter方法: 只要用户发送一次请求,则执行一次,发送多少次请求,此方法就执行多少次,在这个方法中编写过滤规则。
destroy方法: 在Filter对象被销毁释放之前调用,并且只调用一次
- 第二步,在web.xml文件中对Filter进行配置,类似于Servlet对象的配置。配置标签为:
<filter>
<filter-name></filter-name>
<filter-class></filter-class>
</filter>
<filter-mapping>
<filter-name></filter-name>
<url-pattern></url-pattern>
注意:
Servlet对象在默认情况下,在服务器启动的时候是不会新建对象的。
.
Filter对象在默认情况下,在服务器启动的时候会新建对象。
目标的Servlet是否执行,取决于两个条件:
- 在过滤器当中是否编写了代码:
chain.doFilter(request,response);
- 用户发送的请求路径是否和Servlet的请求路径一致
chain.doFilter(request,response);
的作用是
执行下一个过滤器,如果没有过滤器可执行,则执行最终的Servlet
关于Filter和Servlet的优先级
如果一个路径同时对应了一个Filter和一个Servlet,则一定先执行Filter,后执行Servlet。
关于Filter的配置路径
- 精确匹配 (完整路径)
- 模糊匹配,如:
/ * 匹配所有路径
*.后缀 匹配所有以此后缀结尾的路径
3.Filter的调用顺序
- 在web.xml文件当中配置的时候,依靠
filter-mapping
标签的位置,越靠上(越早被编译),优先级越高 - 过滤器的调用顺序遵循栈数据结构
当使用@WebFilter注解的时候,无需在web.xml文件中进行配置,此时,Filter的执行顺序由其类名决定(不推荐)
如:Filter1和Filter2都使用了注解,则先执行Filter1
如:FilterA和FilterB都使用了注解,则先执行FlterA
4.Filter的生命周期
- 和Servlet对象的生命周期几乎一致,唯一区别:
Filter默认情况下,会在服务器启动阶段进行实例化,而Servlet不会。
5.Filter的设计模式
- 在程序编译阶段不会确定调用顺序,因为Filter的调用顺序一般是配置在web.xml文件当中的,只要修改wev,xml配置文件中
filter-mapping
的顺序就可以调整Filter的执行顺序。 - 由此看出,Filter的执行顺序是在程序运行阶段动态组合的,则此设计模式被称为
责任链设计模式
。 - 责任链设计模式的核心思想:
在程序运行时,动态的组合程序的调用顺序。