1.Filter:过滤器
1.web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能
过滤器的作用:
一般用于完成通过的操作,如:登录验证、统一编码处理、敏感字符过滤...
2.快速入门
1.步骤
1.定义一个类,实现制接口Filter
2.复写方法
3.配置拦截路径
package com.filter.servlet;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;
@WebFilter("/*")//这里使用注解配置
public class Filter01 implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
System.out.println("拦截");
chain.doFilter(req, resp);
System.out.println("放行");
}
public void init(FilterConfig config) throws ServletException {
}
}
3.过滤器细节:
1.过滤器执行流程
执行过滤器
执行放行后的资源
回来执行过滤器放行代码下边的代码
2.过滤器生命周期
init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次 用于加载资源
doFilter:每一次请求被拦截资源时,会执行,执行多次
destroy:在服务器关闭后,Filter对象被销毁,如果服务器是正常关闭,则会执行destroy方法,只执行一次,用于释放资源
3.过滤器配置详解
拦截路径配置:
具体资源路径:/index.jsp 只有访问index.jsp资源时,过滤器才会被执行
拦截目录: /users/* 访问/user下的所有资源时,过滤器都会被执行
后缀名拦截:*.jsp 访问所有后缀名为jsp资源时,过滤器都会被执行
拦截所有资源:/* 访问所有资源时,过滤器都会被执行
拦截方式配置:资源被访问的访问
注解配置
设置dispatcherType属性
1.REQUEST: 默认值 浏览器直接请求资源 //浏览器直接请求资源时,该过滤器会被执行
2.FORWARD: 转发访问资源 //转发访问时 该过滤器会被执行
3.INCLUDE: 包含访问资源
4.ERROR: 错误跳转资源
5.ASYNC: 异步访问资源
web.xml配置
<dispatcherType></dispatcherType>
4.过滤器链(配置多个过滤器)
执行顺序:如果有两个过滤器:过滤器1和过滤器2
1.过滤器1
2.过滤器2
3.资源执行
4.过滤器2
5.过滤器1
过滤器先后顺序问题
1.注解配置:按照类名的字符串比较规则比较,值小的先执行
2.web.xml配置:谁定义在上面 谁先执行