Filter
- 配置拦截路径的两种方法
1.1 注解
@WebFilter("/*") //表示对所有路径的资源进行拦截
public class Filter01 implements Filter {
//写一个类实现Filter接口
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("filter进行了拦截");
//放行
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
public void destroy() {
}
}
1.2 web.xml
<filter>
<filter-name>filter01</filter-name>
<filter-class>filter.Filter01</filter-class>
</filter>
<filter-mapping>
<filter-name>filter01</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
- 过滤器执行流程
执行过滤器 -> 执行放行后的资源 -> 回来执行过滤器放行代码下边的代码 - 过滤器生命周期方法
- init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源。
- doFilter:每一次请求被拦截资源时,会执行。执行多次。
- destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次,用于释放资源。
- 过滤器配置
- 拦截路径配置:
- 具体资源路径: /index.jsp 只有访问index.jsp资源时,过滤器才会被执行
- 拦截目录: /user/* 访问/user下的所有资源时,过滤器都会被执行
- 后缀名拦截: *.jsp 访问所有后缀名为jsp资源时,过滤器都会被执行
- 拦截所有资源:/* 访问所有资源时,过滤器都会被执行
- 拦截方式配置:资源被访问的方式
- 注解配置:
- REQUEST:默认值。浏览器直接请求资源
- FORWARD:转发访问资源
- INCLUDE:包含访问资源
- ERROR:错误跳转资源
- ASYNC:异步访问资源
- web.xml配置
设置<dispatcher></dispatcher>
标签即可。
- 过滤器链(配置多个过滤器)
- 假设有两个过滤器:过滤器1和过滤器2
执行顺序 :过滤器1 -> 过滤器2 -> 资源执行 -> 过滤器2 -> 过滤器1 - 过滤器先后顺序问题:
注解配置:按照类名的字符串比较规则比较,值小的先执行。
如: AFilter 和 BFilter,AFilter先执行。
web.xml配置: 谁定义在上边,谁先执行。