SpringBoot拦截器中使用RedisTemplate

这几天想着把登陆拦截器的验证规则修改一下,验证介质由session中获取改为从redis中获取,结果发现redisTemplate一直为空,

java 复制代码
@Configuration
public class WebInterceptorConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //这种方式会拦截所有请求
        registry.addInterceptor(new MyInterceptor());
        //这种方式会拦截指定的请求
//        registry.addInterceptor(new MyInterceptor()).addPathPatterns("/helloInterceptor");
    }
}

上面是修改之前的拦截器代码,很简单,下面是拦截器部分的代码

java 复制代码
public class MyInterceptor implements HandlerInterceptor {

    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

    @Override
    public boolean preHandle(HttpServletRequest request, @NotNull HttpServletResponse response, Object handler) throws Exception {
      //自定义拦截规则
    }
  
  }

可以看到这里使用了ioc自动注入的方式来获取我们预定义好的RedisTemplate对象,但是在调试的过程中失败了,发生了NPE

仔细一想,拦截器在SpringContext初始化之前就执行了,Bean初始化之前它就执行了,所以它肯定是无法获取SpringIOC容器中的内容的。那么我们就让拦截器执行的时候实例化拦截器Bean,在拦截器配置类里面先实例化拦截器,然后再获取就能解决这个问题啦。

下面是修改过后的代码:

javascript 复制代码
public class WebInterceptorConfig implements WebMvcConfigurer {

    @Bean
    public MyInterceptor getLoginHandlerInterceptor(){
        return new MyInterceptor();
    }
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //这种方式会拦截所有请求
        registry.addInterceptor(getLoginHandlerInterceptor());
    }
}

项目启动,完美解决!

相关推荐
cipher36 分钟前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
毅航1 小时前
自然语言处理发展史:从规则、统计到深度学习
人工智能·后端
JxWang051 小时前
Task04:字符串
后端
树獭叔叔2 小时前
10-让模型更小更聪明,学而不忘:知识蒸馏与持续学习
后端·aigc·openai
JxWang052 小时前
Task02:链表
后端
只会cv的前端攻城狮3 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
codetown3 小时前
2026年Zig编程语言权威指南:从系统级底层架构到现代软件工程实践
后端·程序员
cg335 小时前
cc-connect,十分钟帮你把 claude code 连接到微信,飞书,钉钉等等平台
后端·openai
用户1427868669325 小时前
Java多态的底层真相:JVM到底怎么知道该调哪个方法?(面试高频)
后端