全注解实现spring拦截器配置与代码demo
流程说明
1 先基于注解初始化添加一个全局配置的WebMvcConfigurerImpl,实现WebMvcConfigurer接口,这个实现类需要添加自定义拦截器。基于@Bean的方式初始化拦截器能保证在拦截器里面使用@Autowried注入其他Service,不为null。
2 定义自己的拦截器,需要实现HandlerInterceptor接口
3 拦截器是cglib动态代理基于方法级别进行拦截,有三个实现方法,分别是方法前,方法中,方法后,最常用的业务场景是基于方法前进行业务安全校验拦截,通过返回ture,拦截返回false。
4 可以直接在拦截器里面写,也可以单独写一个拦截业务类来编写具体的拦截逻辑,然后注入到自定义拦截器中,调用方法来进行拦截。
代码demo
WebMvcConfigurerImpl
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Bean
public MyInterceptor initInterceptor() {
return new MyInterceptor();
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(initInterceptor()).addPathPatterns("/**");
}
}
自定义拦截器
public class MyInterceptor implements HandlerInterceptor {
@Autowired
private InterceptorService interceptorService;
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
/*
* 拦截条件
*/
if (interceptorService.interceptor()) {
return false;
}
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
拦截器里面注入的拦截ServiceBean
@Service
public class InterceptorService {
public boolean interceptor() {
return false;
}
}
常见问题
1 如果不想拦截全部的url,在定义WebMvcConfigurerImpl时,会基于url来判断拦截的url,demo中写的是/**,可以基于excludePathPatterns(“/login”)这种方式来添加不需要拦截的地址。
2 如果需要在拦截器中基于@Autowired注入SpringBean,初始化拦截器时,也需要基于@Bean来初始化。否则,将出现注入的bean为null,这是因为拦截器的加载顺序默认时优先于SpringBean的初始化的。