shiro造成dubbo无法注入java.lang.IllegalStateException: ApplicationEventMulticaster not initialized

本文介绍在项目中同时使用Shiro和Dubbo时遇到的异常情况及解决方法。详细解析了Shiro如何影响Dubbo的服务注入,并给出了解决方案。

1在使用shiro和dubbo的时候,启动项目报如下相关异常信息


2启动项目加载web.xml时会加载

	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>
			classpath:applicationContext.xml
		</param-value>
	</context-param>
3applicationContext.xml引入了shiro和dubbo的配置

<!-- 引入所需配置文件 -->
<import resource="classpath*:spring/dubbo.xml" />
<import resource="classpath*:spring/redis.xml" />
<import resource="classpath*:spring/session.xml" />
<import resource="classpath*:spring/shiro.xml" />
4shiro.xml中配置了shirofilter,securitymanager,realm等

5跟了一下shirofilter的源码发现


6dubbo是注入了bean,而shiro拦截了所有的bean的注入,交给SecurityManager;

7初始化shiro判断bean是否实现了filter,判断dubbo是否注入了相关的service,最后就会出现shiro造成dubbo无法注入的现象。

8解决办法,在初始化application.xml时,加上如下配置。

<!-- shiro会造成dubbo的服务无法注入,所以相关service通过配置文件解决 -->
<dubbo:reference id="xxService" interface="com.xxx.xxx.sys.service.xxService" check="false" />
<dubbo:reference id="xxService" interface="com.xxx.xxx.sys.service.xxService" check="false" />
9源码太深奥,以上只是个人见解和解决办法,微笑



### Shiro框架中IllegalStateException异常的解决方法 在使用Shiro框架时,如果遇到`java.lang.IllegalStateException`异常,通常是因为配置文件或代码中的某些条件未满足导致的问题。以下是可能的原因及解决方案。 #### 1. 异常原因分析 `java.lang.IllegalStateException`异常通常与Shiro的`ShiroFilterFactoryBean`配置相关[^4]。该异常可能由以下几种情况引起: - `ShiroFilterFactoryBean`的`filterChainDefinitions`属性未正确配置。 - Spring容器初始化顺序错误,导致`ShiroFilterFactoryBean`在依赖项未准备好之前被初始化。 - 缺少必要的过滤器定义或路径映射。 #### 2. 解决方案 以下是针对上述问题的具体解决方法: ##### 2.1 检查`filterChainDefinitions`配置 确保`ShiroFilterFactoryBean`的`filterChainDefinitions`属性已正确设置。例如: ```java @Bean public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); // 配置访问权限 Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>(); filterChainDefinitionMap.put("/login", "anon"); // 登录页面无需认证 filterChainDefinitionMap.put("/**", "authc"); // 其他页面需要认证 shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } ``` 如果路径或过滤器名称配置错误,可能会导致非法状态异常[^5]。 ##### 2.2 确保Spring容器初始化顺序正确 `ShiroFilterFactoryBean`依赖于`SecurityManager`,因此必须确保`SecurityManager`在`ShiroFilterFactoryBean`初始化之前已经完成加载。可以通过以下方式实现: ```java @Bean public SecurityManager securityManager() { DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); securityManager.setRealm(myRealm()); return securityManager; } @Bean public MyRealm myRealm() { return new MyRealm(); } ``` 如果`SecurityManager`未正确注入到`ShiroFilterFactoryBean`中,可能会引发`IllegalStateException`异常。 ##### 2.3 检查过滤器是否正确注册 确保所有必需的过滤器(如`anon`、`authc`等)已在`ShiroFilterFactoryBean`中注册。如果缺少某些过滤器,可能会导致运行时异常。例如: ```java shiroFilterFactoryBean.getFilters().put("anon", new AnonymousFilter()); shiroFilterFactoryBean.getFilters().put("authc", new FormAuthenticationFilter()); ``` #### 3. 示例代码 以下是一个完整的Shiro配置示例,确保不会出现`IllegalStateException`异常: ```java @Configuration public class ShiroConfig { @Bean public SecurityManager securityManager() { DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); securityManager.setRealm(myRealm()); return securityManager; } @Bean public MyRealm myRealm() { return new MyRealm(); } @Bean public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>(); filterChainDefinitionMap.put("/login", "anon"); filterChainDefinitionMap.put("/**", "authc"); shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } } ``` #### 4. 注意事项 - 如果使用Spring Boot,请确保未排除Shiro相关的自动配置类[^6]。 - 检查日志输出,确认是否有其他潜在问题导致异常。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值