Filter
Filter简介
- 概念:Filter表示过滤器,是Javaweb三大组件之一(Servlet,Filter,Listener)之一
- 过滤器可以把资源的请求拦截下来,从而实现一些特殊的功能
- 过滤器一般完成一些通用的操作,比如:权限控制,统一编码处理,敏感字符处理等等...
Filter快速入门
- 定义类,实现Filter接口,并重写其所有方法
publicclassFilterDemo1implementsFilter {
@Override
publicvoiddoFilter(ServletRequestservletRequest, ServletResponseservletResponse, FilterChainfilterChain) throwsIOException, ServletException {}
@Override
publicvoidinit(FilterConfigfilterConfig) throwsServletException {}
@Override
publicvoiddestroy() {}
}
- 配置Filter拦截资源的路径,在类上定义@WebFilter注解
@WebFilter("/*")
publicclassFilterDemo1implementsFilter {
- 在doFilter方法中输出一句话,并放行
publicvoiddoFilter(ServletRequestservletRequest, ServletResponseservletResponse, FilterChainfilterChain) throwsIOException, ServletException {
//1放行前,对request数据进行处理
System.out.println("filter,被执行了。。。");
//放行
filterChain.doFilter(servletRequest, servletResponse);
//2放行后,对response数据进行处理
System.out.println("3.FilterDemo...");
}
Filter执行流程
- 放行后访问对应资源,资源访问完成后,还会回到Filter中
- 如果回到Filter中,是重头执行还是执行放行后的逻辑?
当然是放行后的逻辑,顺序是执行放行前逻辑->放行->访问资源->执行放行后逻辑
Filter拦截路径配置
- Filter可以根据需求,配置不同的拦截资源路径
@WebFilter("/*")这里设置拦截不同的资源
- 拦截具体的资源:/index.jsp:只有访问index.jsp时才会被拦截
- 目录拦截:/user/*:访问/user下的所有资源,都会被拦截
- 后缀名拦截:*.jsp:访问后缀名为jsp的资源,都会被拦截
- 拦截所有:/*:访问所有资源。都会被拦截
过滤器链
- 一个web应用,可以配置多个过滤器,着多个过滤器称为过滤器链
- 注解配置的Filter,优先级按照过滤器类名(字符串)的自然排序