springboot拦截器注入RedisTemplate为空

最近在研究使用Redis+拦截器实现验证,大致实现方法为在拦截器中用RedisTemplate向Redis中记录请求剩余时间,但是在测试中发现在拦截器中,RedisTemplate注入不进来,一直为null。

我的拦截器如下:

public class LoginHandleInterceptor implements HandlerInterceptor {
    @Resource
    private RedisTemplate redisTemplate;
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        //获取header中的参数
        String token = request.getHeader("token")==null? "":request.getHeader("token");

        //查询token在redis中的剩余时间
        Long expire = redisTemplate.getExpire(token);

        if(expire>0){//登入状态
            //重新设置缓存时间
            redisTemplate.expire(token,30L, TimeUnit.MINUTES);
            //已登入,放行
           return true;
        }else{
            //未登入,相应数据
            return false;
        }
    }
}

使用postman调用的时候。发现出现了空指针异常,debug发现,LoginHandleInterceptor 中的Redistemplate为null。

静下来想一想,拦截器加载的时间点在springcontext之前,即在bean实例化之前,所以在拦截器中注入自然为null 。那么我们就让拦截器执行的时候实例化拦截器Bean,在拦截器配置类里面先实例化拦截器,然后再获取就能解决这个问题啦。

@Configuration
public class MyMvcConfig implements WebMvcConfigurer {
    @Bean
    public LoginHandleInterceptor getSessionInterceptor() {
        return new LoginHandleInterceptor();
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(getSessionInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/login");
    }
}
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值