拦截器的简单介绍
拦截器是Spring提供的HandlerInterceptor(拦截器),其功能和过滤器类似,但是提供更精细的控制能力:在request被响应之前、request被响应之后、视图渲染之前以及request全部结束之后。我们不能通过拦截器修改request的内容,但可以通过抛出异常(或者返回false)来暂停request的执行。并且在拦截其中可以通过@autowired 来获取其他bean,相比过滤器而言非常方便
拦截器的基本使用
自定义拦截器
@Component
public class Interceptor001 implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("执行 preHandler...................");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("执行 postHandler......................");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("执行 afterCompletion.....................");
}
}
在springboot中通过继承 WebMvcConfigurer 来注册自定义的拦截器
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Autowired
private Interceptor001 interceptor001;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(interceptor001).addPathPatterns("/test1/**");
}
}
1.以上配置会拦截 /test1/** 下所有的请求进入拦截器
2.自定义拦截器执行顺序 preHandle->postHandle->afterCompletion
3.若postHandle 返回true 则执行postHandle->controller->postHandle->afterCompletion
4.若postHandle 返回false 则执行postHandle-> end(结束,不会进入controller)