过滤器,可以拦截所有的请求与响应。
Filter 声明周期 :它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁。
使用Filter完整的流程是:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理。
什么场景 会使用 Filter?
- 日志:比如 张三 XX时间 访问了 什么什么接口 等待
- 用户授权:负责检查用户请求,根据请求过滤用户非法请求。
- 非标准编码的请求解码:可以解决 一些字符集啊 之类的问题
一个请求或响应也可以被多个Filter拦截
如何使用Filter?
实现javax.servlet.Filter 接口,重写其 init()、destory()、doDilter()方法
1、在启动类上开启
代码语言:javascript复制@ServletComponentScan
2、在config 层 写一个 配置类
代码语言:javascript复制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() {
}
}
完成!
特殊说明: 解决问题的光鲜,藏着磕Bug的痛苦。 万物皆入轮回,谁也躲不掉! 以上文章,均是我实际操作,写出来的笔记资料,不会出现全文盗用别人文章!烦请各位,请勿直接盗用!