由于shiroFilter在Spring自动装配bean之前实例化
在继承了AuthorizingRealm
的类里使用依赖注入的bean及相关联的Bean会被初始化完成且没有被代理(包括BeanPostProcessor也会无效)导致事务失效等......
此种情形只在SpringBoot出现,SpringMVC方式不会
此时的service在bean中注入,但是调试发现并没有被进行代理,所以导致Spring-AOP切面事务失效
所以采取的方式是不在bean初始化时注入Bean,而在程序运行后动态从SpringContext上下文中获取
/**
* 前置处理非空对象
* shiroFilter在Spring自动装配bean之前实例化
* 相关联的Bean都被初始化完成且没有被代理(包括BeanPostProcessor也会无效)导致事务失效等......
* 使用动态获取代理对象即可解决
*/
protected void preHandleNull() {
if (null == sysMenuService) {
sysMenuService = SpringContextUtils.getBean(SysMenuService.class);
}
if (null == sysUserService) {
sysUserService = SpringContextUtils.getBean(SysUserService.class);
}
if (null == constant) {
constant = SpringContextUtils.getBean(Constant.class);
}
}
在认证和授权方法调用前调用preHandleNull()
方法初始化即可,此时对象已被动态代理
实现方法其实很简单,只是给了个思路。如果有更好的解决方法可以后续评论