Filter过滤器
概念:Filter 表示过滤器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一。
过滤器可以把对资源的请求拦截下来,从而实现一些特殊的功能。
过滤器一般完成一些通用操作,比如:权限控制、统一编码处理、敏感字符处理等。
一、Filter的实现:
- 定义类,实现Filter接口,并重写其所有方法
public class FilterDemo implements Filter {//实现的接口Filter来自javax.servlet包
@Override
public void init(FilterConfig filterConfig) throws ServletException {}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {}
@Override
public void destroy() {}
}
2.配置Filter拦截资源路径:在类上定义@WebFilter
注解
@WebFilter("/*")// /*表示拦截所有资源路径
public class FilterDemo implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {}
@Override
public void destroy() {}
}
3.在doFilter方法中输出一句话,并放行
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("FilterDemo...");
//放行
chain.doFilter(request,response);//放行,让其访问本该访问的资源。
}
二、Filter的执行流程
放行后访问对应资源,资源访问完成后,还会回到Filter中,并且会回到 放行后逻辑,执行该部分代码。所以Filter执行流程如下:
三、Filter拦截路径配置
拦截路径表示 Filter 会对请求的哪些资源进行拦截,使用 @WebFilter
注解进行配置。如:@WebFilter("拦截路径")
拦截路径有如下四种配置方式:
- 拦截具体的资源:/index.jsp:只有访问index.jsp时才会被拦截
- 目录拦截:/user/*:访问/user下的所有资源,都会被拦截
- 后缀名拦截:*.jsp:访问后缀名为jsp的资源,都会被拦截
- 拦截所有:/*:访问所有资源,都会被拦截
四、过滤器链
过滤器链是指在一个Web应用,可以配置多个过滤器,这多个过滤器称为过滤器链。
上图中的过滤器链执行是按照以下流程执行:
执行 Filter1
的放行前逻辑代码------>执行 Filter1
的放行代码------>执行 Filter2
的放行前逻辑代码------>执行 Filter2
的放行代码------>访问到资源------>执行 Filter2
的放行后逻辑代码------>执行 Filter1
的放行后逻辑代码
过滤器链的执行顺序:
优先级是按照过滤器类名(字符串)的自然排序。例如,有如下两个名称的过滤器 : BFilterDemo
和 AFilterDemo
。那一定是 AFilterDemo
过滤器先执行。