快速入门
@WebFilter("/*")
public class FilterTest implements 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("test");
filterChain.doFilter(servletRequest, servletResponse);
}
@Override
public void destroy() {
}
}
细节
- xml配置
<filter>
<filter-name>demo</filter-name>
<filter-class>xyz.chenjinsui.filter.FilterTest</filter-class>
</filter>
<filter-mapping>
<filter-name>demo</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
- 执行流程
- 执行过滤器
- 执行放行后的资源
- 回来执行过滤器放行代码下的代码
- 生命周期方法
- init:服务器启动后,会创建FIlter对象,然后调用init方法。只执行一次
- deFilter:每一次请求被拦截资源时,会执行。执行多次
- destroy:在服务器正常关闭后,Filter对象被销毁。只执行一次,用于释放资源
- 配置详解
- 配置拦截路径:
- 具体资源路径 /index.jsp
- 拦截目录 /user/*
- 后缀名拦截 /*.jsp
- 拦截所有资源 /*
- 配置拦截方式
- 注解配置:设置dispatcherTypes属性
- xml配置:设置
<dispatcher></dispatcher>
标签
取值 | 含义 |
---|
REQUEST | 默认值,浏览器直接请求资源 |
FORWARD | 转发请求资源 |
INCLUDE | 包含访问资源 |
ERROR | 错误跳转资源 |
ASYNC | 异步访问资源 |
- 过滤器链
一个项目中会存在多个过滤器,它们的执行顺序类似于栈。注解配置的Filter按照类名的字典序升序排序,web.xml配置的Filter按照<filter-mapping>
定义的先后排序。