Spring boot拦截器HandlerInterceptor

过滤器是servlet范畴的API,和spring没有关系,web开发中,我们除了使用Filter来过滤web请求外,还可以使用spring提供的HandlerInterceptor(拦截器)
HandlerInterceptor的功能和过滤器相似,但是提供了更精细的控制能力:在request被相应之前,request被响应后,试图渲染之前以及request全部结束之后。我们不能通过拦截器修改request内容,但是可以通过抛出异常(或者返回false)来暂停request执行
配置拦截器只需要重写addInterceptors方法来添加注册拦截器
实现自定义拦截器只需要三步
1.    创建我们自己的拦截器类并实现HandlerInterceptor接口
2.    创建一个java类来继承WenMvcConfigurerAdapter,并重写addInterceptors方法
3.    实例化我们自定义的拦截器,然后将对象手动添加到拦截器链中(在addInterceptors方法中添加)

public class MyInterceptor1 implements HandlerInterceptor {
    @Override
    publicboolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        System.out.println(">>>MyInterceptor1>>>>>>>在请求处理之前进行调用(Controller方法调用之前)");
 
        return true;// 只有返回true才会继续向下执行,返回false取消当前请求
    }
    @Override
    publicvoid postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println(">>>MyInterceptor1>>>>>>>请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)");
    }
    @Override
    publicvoid afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println(">>>MyInterceptor1>>>>>>>在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)");
    }
}
@Configuration
public class MyWebAppConfigurer extends WebMvcConfigurerAdapter {
    @Override
    publicvoid addInterceptors(InterceptorRegistry registry) {
        // 多个拦截器组成一个拦截器链
        // addPathPatterns 用于添加拦截规则
        // excludePathPatterns 用户排除拦截
        registry.addInterceptor(new MyInterceptor1()).addPathPatterns("/**");
        registry.addInterceptor(new MyInterceptor2()).addPathPatterns("/**");
        super.addInterceptors(registry);
    }
}


评论

*
*