SpringBoot>09 - 过滤器、监听器、拦截器,Aspect切片

简介:

本章介绍拦截器、过滤器、切片对请求拦截的使用与区别,以及监听器在 springboot1.5 中的简单使用

个人学习总结:
链接:【springboot、springcloud、docker 等,学习目录

过滤器、拦截器、切片拦截请求的对比:

相同点: 都可以对请求进行拦截。
不同点:
1、过滤器对请求的拦截只能获取到原始的Request 和 Response 的信息。
2、拦截器对请求的拦截可以获取原始的Request、Response和所有的controller及方法名,但无法获取方法的参数信息。
3、Aspect切片只能获取方法的参数,原始的Request、Response不能获取。

所以,实际项目需根据需求选择使用何种方式拦截请求。

一、过滤器:

1、实现Filter接口

/**
 * @Auther: xf
 * @Date: 2018/11/19 19:30
 * @Description: 自定义过滤器
 *
 * Filter 只能获取request 和 response 并不知道请求是哪个 controller 处理的
 */
@Slf4j
public class CustomFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        log.info("过滤器初始化>>>>>>>");
    }

    /**
     * 请求被拦截的时候进行调用
     */
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        log.info(">>>>>>>>>>>>过滤器拦截请求处理逻辑>>>>>>>>>>>>>");

        // 业务逻辑
        long startTime = System.currentTimeMillis();

        // 过滤器链,给下一个过滤器
        filterChain.doFilter(servletRequest, servletResponse);
        log.info("请求时间:" + (System.currentTimeMillis() - startTime));
    }

    @Override
    public void destroy() {
        log.info("过滤器销毁>>>>>>>");
    }
}

2、过滤器配置类:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值