1.1、概念:
- 生活中的过滤器:净水器,空气净化器,土匪、
- web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。
- 过滤器的作用:
- 一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符过滤…
1.2、 快速入门:
1. 步骤:
- 定义一个类,实现接口Filter
- 复写方法
- 配置拦截路径
- web.xml
- 注解
2. 代码:
1 |
|
1.3、 过滤器细节:
1. web.xml配置
1 | <filter> |
2. 过滤器执行流程
- 执行过滤器
- 执行放行后的资源
- 回来执行过滤器放行代码下边的代码
1
2
3
4
5
6
7
8public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
//对request对象请求消息增强
System.out.println("FilterDemo02....执行了");
//放行
chain.doFilter(req, resp);
//对response对象响应消息增强
System.out.println("FilterDemo02....回来了");
}
3. 过滤器生命周期方法
- init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源。
- doFilter:每一次请求被拦截资源时,会执行。执行多次。
- destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源。
4. 过滤器配置详解:拦截路径,拦截方式
拦截路径配置:
- 具体资源路径:
/index.jsp
只有访问index.jsp资源时,过滤器才会被执行 - 拦截目录:
/user/*
访问/user下的所有资源时,过滤器都会被执行 - 后缀名拦截:
*.jsp
访问所有后缀名为jsp资源时,过滤器都会被执行 - 拦截所有资源:
/*
访问所有资源时,过滤器都会被执行1
2
3
4"/index.jsp") (
"/user/*") (
"*.jsp") (
"/*") (
- 具体资源路径:
拦截方式配置:资源被访问的方式
- 注解配置:
- 设置dispatcherTypes属性
- REQUEST:默认值。浏览器直接请求资源
- FORWARD:转发访问资源
- INCLUDE:包含访问资源
- ERROR:错误跳转资源
- ASYNC:异步访问资源
1
2
3
4
5
6//只有浏览器直接请求index.jsp资源时,该过滤器才会被执行
"/index.jsp",dispatcherTypes =DispatcherType.REQUEST) (value =
//只有浏览器转发请求index.jsp资源时,该过滤器才会被执行
"/index.jsp",dispatcherTypes =DispatcherType.FORWARD) (value =
//浏览器直接请求,或者转发访问index.jsp时。该过滤器都会被执行
"/index.jsp",dispatcherTypes = {DispatcherType.FORWARD,DispatcherType.REQUEST}) (value =
- 设置dispatcherTypes属性
- web.xml配置
- 设置
<dispatcher></dispatcher>
标签即可1
2
3
4
5<filter-mapping>
<filter-name>demo01</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>ASYNC</dispatcher>
</filter-mapping>
- 设置
5. 过滤器链(配置多个过滤器)
执行顺序:如果有两个过滤器:过滤器1和过滤器2
- 过滤器1
- 过滤器2
- 资源执行
- 过滤器2
- 过滤器1
过滤器先后顺序问题:
- 注解配置:按照类名的字符串比较规则比较,值小的先执行 按索引比较
- 如: AFilter 和 BFilter,AFilter就先执行了。 A12优先A2
- web.xml配置:
<filter-mapping>
谁定义在上边,谁先执行
- 注解配置:按照类名的字符串比较规则比较,值小的先执行 按索引比较