Filter过滤器
例如一个登录功能,用户登录之后才能操作某些功能,如果在这些功能执行之前都是需要判断用户是否登录,
这段判断用户是否登录的代码是固定的,并且在每一个Servlet类当中都需要编写,显然代码没有得到重复利用。
包括每一个Servlet都要解决中文乱码问题,也有公共的代码。这些代码目前都是重复编写,并没有达到复用。
可以使用Servlet规范中的Filter过滤器来解决这个问题。
Filter的作用
Filter可以在Servlet这个目标程序执行之前添加代码。也可以在目标Servlet执行之后添加代码。之前之后都可以添加过滤规则。
一般情况下,都是在过滤器当中编写公共代码。
过滤器怎么写呢?
- 第一步:编写一个Java类实现一个接口:jarkata.servlet.Filter。并且实现这个接口当中所有的方法。
init方法:在Filter对象第一次被创建之后调用,并且只调用一次。
doFilter方法:只要用户发送一次请求,则执行一次。发送N次请求,则执行N次。在这个方法中编写过滤规则。
destroy方法:在Filter对象被释放/销毁之前调用,并且只调用一次。 - 第二步:在web.xml文件中对Filter进行配置。这个配置和Servlet很像。
<filter>
<filter-name>filter</filter-name>
<filter-class>com.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
或者使用注解:@WebFilter({“/*”})
注意:
- Servlet对象默认情况下,在服务器启动的时候是不会新建对象的。
- Filter对象默认情况下,在服务器启动的时候会新建对象。
- Servlet是单例的。Filter也是单例的。(单实例。)
目标Servlet执行条件
- 第一:在过滤器当中是否编写了:chain.doFilter(request, response); 代码。//执行下一个过滤器,如果下面没有过滤器了,执行最终的Servlet。
- 第二:用户发送的请求路径是否和Servlet的请求路径一致。
关于Filter的配置路径
- /a、/b、/user/save。这些配置方式都是精确匹配。
- /* 匹配所有路径。
- *.do 后缀匹配。不要以 / 开始,例如/a.do /b.do 都能匹配
- /user/* 前缀匹配。例如/user/a,/user/b都能匹配
Filter的优先级
- Filter的优先级,天生的就比Servlet优先级高。
- 在web.xml文件中进行配置的时候,依靠filter-mapping标签的配置位置,越靠上优先级越高。
- 使用@WebFilter的时候,执行顺序是:比较类名。例如:FilterA和FilterB,则先执行FilterA。Filter1和Filter2,则先执行Filter1.
Filter的生命周期
和Servlet对象生命周期一致。
- 唯一的区别:Filter默认情况下,在服务器启动阶段就实例化。Servlet不会。