1.Filter:过滤器
    1.web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能
       过滤器的作用:
        一般用于完成通过的操作,如:登录验证、统一编码处理、敏感字符过滤...

Filter
  

 2.快速入门
        1.步骤
            1.定义一个类,实现制接口Filter
            2.复写方法
            3.配置拦截路径

package com.filter.servlet;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;

@WebFilter("/*")//这里使用注解配置
public class Filter01 implements Filter {
    public void destroy() {
    }

    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
        System.out.println("拦截");
        chain.doFilter(req, resp);
        System.out.println("放行");
    }

    public void init(FilterConfig config) throws ServletException {

    }

}

    3.过滤器细节:
        1.过滤器执行流程
            执行过滤器
            执行放行后的资源
            回来执行过滤器放行代码下边的代码
        2.过滤器生命周期
            init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次 用于加载资源
            doFilter:每一次请求被拦截资源时,会执行,执行多次
            destroy:在服务器关闭后,Filter对象被销毁,如果服务器是正常关闭,则会执行destroy方法,只执行一次,用于释放资源
        3.过滤器配置详解
            拦截路径配置:
                具体资源路径:/index.jsp  只有访问index.jsp资源时,过滤器才会被执行
                拦截目录: /users/*  访问/user下的所有资源时,过滤器都会被执行
                后缀名拦截:*.jsp  访问所有后缀名为jsp资源时,过滤器都会被执行
                拦截所有资源:/*  访问所有资源时,过滤器都会被执行
            拦截方式配置:资源被访问的访问
                注解配置
                    设置dispatcherType属性
                        1.REQUEST: 默认值 浏览器直接请求资源  //浏览器直接请求资源时,该过滤器会被执行
                        2.FORWARD: 转发访问资源  //转发访问时 该过滤器会被执行
                        3.INCLUDE: 包含访问资源
                        4.ERROR: 错误跳转资源
                        5.ASYNC: 异步访问资源
                web.xml配置
                    <dispatcherType></dispatcherType>
        4.过滤器链(配置多个过滤器)
            执行顺序:如果有两个过滤器:过滤器1和过滤器2
                1.过滤器1
                2.过滤器2
                3.资源执行
                4.过滤器2
                5.过滤器1
            过滤器先后顺序问题
                1.注解配置:按照类名的字符串比较规则比较,值小的先执行
                2.web.xml配置:谁定义在上面 谁先执行

相关文章: