由于最近有个项目需要用到springboot+shiro,所以抽空的时候自己做了一个小demo学习一下。但是当项目搭建完毕,启动的时候却报了个错,提示我无法创建shiroFilterFactoryBean,如图:
后面还有一个控制指针的报错。经过在Debug模式下调试,发现是因为通过autowired注解注入的一个Service没有注入成功,如下:
开始以为是其他地方少写了注解的原因,经过仔细排查没有发现任何问题,于是在网上寻找解决方法,看到有网友提出说是因为在@Configuration注解里@AutoWired注解会失效,导致注入不成功。然后按照他们给出的解决方案去尝试还是不行,于是开始继续在网上找解决方法。受到一位网友的启发,想到可能是配置类里面的某一个bean对象有问题,于是想到把bean对象逐一注释掉,测试一***释的第一个bean对象是LifecycleBeanPostProcessor,这个是管理shiro生命周期的一个对象,注释之后启动服务,发现没有报错,启动成功,服务也注入成功了。至于无法创建shiroFilterFactoryBean,是因为在创建这个bean的方法中用到了注入进来的服务里的方法,由于之前注入失败,报出了空指针的异常,这个bean对象也就创建失败了,注释LifecycleBeanPostProcessor之后启动服务:
至此,这个问题算是解决了,至于为什么LifecycleBeanPostProcessor对象会使@AutoWired注解失效,还有待深究。