(转载)SpringBoot+Shiro引起事务失效的错误原因和解决方法

在工作中,偶然发现的这个问题,当前使用的springboot2.0.5+mybatis-plus3.0.5+shiro1.4.0搭的项目。但是在测试过程中发现,有关用户,角色,菜单,部门部分的service层代码有些会出现事务无法回滚的情况。
经过多次尝试,一度怀疑是mybatis-plus的问题,但是发现其他业务中(和用户,角色,菜单、部门无关的)事务照样可以回滚,顿时感觉可能是shiro出问题了。
参照以下两篇文章:
SpringBoot+Shiro引起事务失效、错误原因、解决方法
spring + shiro 配置中部分事务失效分析及解决方案
加上项目启动日志:
在这里插入图片描述
总结下来就是:
由于ShiroFilterFactoryBean实现了FactoryBean接口,所以它会提前被初始化。又因为SecurityManager,SecurityManager依赖于Realm实现类、Realm实现类又依赖于UserService,所以引发所有相关的bean提前初始化。

ShiroFilterFactoryBean -> SecurityManager -> Realm实现类 -> UserService

但是此时还只是ApplicationContext中registerBeanPostProcessors注册BeanPostProcessor处理器的阶段,此时AnnotationAwareAspectJAutoProxyCreator还没有注册到BeanFactory中,UserService无法享受到事务处理!
就是说在realm中注入的所有service都会提前加载,连带注入的service中,如果还有其他service注入也会提前加载,无法享受事务处理。
解决方案:
1.在realm中注入service时,加上@lazy注解
2.不在realm注入service,而是直接注入mapper

猜你喜欢

转载自blog.csdn.net/qq_38846242/article/details/84033180