(三)、SpringBoot 自定义 interceptor(拦截器)

本文介绍如何在Spring MVC中创建并使用自定义拦截器,包括实现HandlerInterceptor接口的TimeInterceptor类,记录请求处理时间,并在配置文件中注册拦截器。

可以前往第一篇博客查看目录结构 --> 这里

一、创建interceptor包


二、在interceptor包下创建TimeInterceptor类,自定义Interceptor

@Component
public class TimeInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("interceptor preHandle");
        System.out.println(((HandlerMethod)handler).getBean().getClass().getName());
        System.out.println(((HandlerMethod)handler).getMethod().getName());
        request.setAttribute("start",new Date().getTime());
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("interceptor postHandle");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("interceptor afterCompletion");
        long start = (long) request.getAttribute("start");
        System.out.println("interceptor耗时: " + (new Date().getTime() - start));
    }
}

三、在config包下的WebConfig类下添加下述代码,配置自定义的TimeInterceptor进入

    @Autowired
    private TimeInterceptor timeInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(timeInterceptor);
    }

四、访问 localhost/user ,查看IDEA控制台即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值