过滤器,可以拦截所有的请求与响应。

Filter 声明周期 :它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁。

使用Filter完整的流程是:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理。

什么场景 会使用 Filter?

  • 日志:比如 张三 XX时间 访问了 什么什么接口 等待
  • 用户授权:负责检查用户请求,根据请求过滤用户非法请求。
  • 非标准编码的请求解码:可以解决 一些字符集啊 之类的问题

一个请求或响应也可以被多个Filter拦截

如何使用Filter?

实现javax.servlet.Filter 接口,重写其 init()、destory()、doDilter()方法

1、在启动类上开启

@ServletComponentScan

2、在config 层 写一个 配置类

package com.govbuy.config;
import lombok.extern.slf4j.Slf4j;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;


/**
 * 作者:臧立昆
 * 2020/10/16 13:11
 */

@Slf4j
@WebFilter(filterName = "myFilter", urlPatterns = "/*")
public class MyFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) {
        //log.info(filterConfig.getFilterName() + " init");
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
        try {
            //long time = new Random().nextInt(2000)+ 1000;
            //Thread.sleep(time);
         chain.doFilter(request, response);
        } catch (Exception e) {
            //log.error("error!", e);
        }
        //log.info("过滤器 end");
    }

    @Override
    public void destroy() {
    }
}

完成!