SpringBoot拦截器
Spring MVC中提供了AOP风格的拦截器,拥有更加精细的拦截处理能力。Spring Boot中拦截器的注册如下:
依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
创建拦截器:
实现HandlerInterceptor接口
public class MyInterceptor1 implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) { System.out.println("MyInterceptor1>>>preHandle"); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) { System.out.println("MyInterceptor1>>>postHandle"); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { System.out.println("MyInterceptor1>>>afterCompletion"); } }
拦截器中的方法将按preHandle→Controller→postHandle→afterCompletion的顺序执行。注意,只有preHandle方法返回true时后面的方法才会执行。当拦截器链内存在多个拦截器时,postHandler在拦截器链内的所有拦截器返回成功时才会调用,而afterCompletion只有preHandle返回true才调用,但若拦截器链内的第一个拦截器的preHandle方法返回false,则后面的方法都不会执行。
配置拦截器:
定义配置类进行拦截器的配置
@Configuration public class WebMvcConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor1()) .addPathPatterns("/**") .excludePathPatterns("/hello"); } }
自定义类实现WebMvcConfigurer接口,实现接口中的addInterceptors方法。其中,addPathPatterns表示拦截路径,excludePathPatterns表示排除的路径。
测试:
在浏览器中提供/hello2和/hello接口分别进行访问,当访问/hello接口时,打印日志
文章来源: Spring Boot+Vue全栈开发实战 - 4.8 注册拦截器