这几天想着把登陆拦截器的验证规则修改一下,验证介质由session中获取改为从redis中获取,结果发现redisTemplate一直为空,
@Configuration
public class WebInterceptorConfig implements WebMvcConfigurer {@Overridepublic void addInterceptors(InterceptorRegistry registry) {//这种方式会拦截所有请求registry.addInterceptor(new MyInterceptor());//这种方式会拦截指定的请求
// registry.addInterceptor(new MyInterceptor()).addPathPatterns("/helloInterceptor");}
}
上面是修改之前的拦截器代码,很简单,下面是拦截器部分的代码
public class MyInterceptor implements HandlerInterceptor {@Autowiredprivate RedisTemplate<String, Object> redisTemplate;@Overridepublic boolean preHandle(HttpServletRequest request, @NotNull HttpServletResponse response, Object handler) throws Exception {//自定义拦截规则}}
可以看到这里使用了ioc自动注入的方式来获取我们预定义好的RedisTemplate对象,但是在调试的过程中失败了,发生了NPE
仔细一想,拦截器在SpringContext初始化之前就执行了,Bean初始化之前它就执行了,所以它肯定是无法获取SpringIOC容器中的内容的。那么我们就让拦截器执行的时候实例化拦截器Bean,在拦截器配置类里面先实例化拦截器,然后再获取就能解决这个问题啦。
下面是修改过后的代码:
public class WebInterceptorConfig implements WebMvcConfigurer {@Beanpublic MyInterceptor getLoginHandlerInterceptor(){return new MyInterceptor();}@Overridepublic void addInterceptors(InterceptorRegistry registry) {//这种方式会拦截所有请求registry.addInterceptor(getLoginHandlerInterceptor());}
}
项目启动,完美解决!