一、Filter概述
概念:Filter表示过滤器,是JavaWeb三大组件(Servlet、Filter、Listener)之一。
过滤器可以把对资源的请求拦截下来,从而实现一些特殊的功能
过滤器一般完成一些通用的操作,比如:权限控制,统一编码处理,敏感字符处理等等....
二、Filter入门案例
1、定义类,实现Filter接口,并重写其所有方法
public class FilterDemo implements Filter { @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { } @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void destroy() { } }
2、配置Filter拦截资源的路径:在类上定义@WebFilter注解
@WebFilter("/*") public class FilterDemo implements Filter {
3、在doFilter方法中输出一句话,并放行
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("FilterDemo..."); //放行 filterChain.doFilter(servletRequest,servletResponse); }
三、Filter执行流程
放行后访问对应资源,资源访问完成后,还会回到Filter中。回到Filter中,是执行放行后的逻辑。放行前执行完之后,再执行完资源,再执行放行后逻辑。
四、Filter拦截路径配置
Filter可以根据需求,配置不同的拦截资源路径
@WebFilter("/*") public class FilterDemo
拦截具体的资源:/index.jsp:只有访问index.jsp时才会被拦截。
目录拦截:/user/*:访问/user下的所有资源,都会被拦截
后缀名拦截:*.jsp:访问后缀名为jsp的资源,都会被拦截
拦截所有:/*:访问所有资源,都会被拦截
五、过滤器链
一个web应用,可以配置多个过滤器,这多个过滤器称为过滤器链
过滤器链最先执行Filter1放行前逻辑,再执行Filter2放行前逻辑,再执行资源,再执行Filter2放行后逻辑,最后执行Filter1放行后逻辑。
注意:注解配置的Filter,优先级按照过滤器类名(字符串)的自然排序。