Shiro报错 No SecurityManager accessible to the calling code, either bound to the org.apache.shiro.util

本文主要介绍了在Struts2+Spring+Hibernate整合Shiro框架时遇到的'No SecurityManager accessible'错误,详细解析了报错详情、报错场景,并提供了解决方案,包括检查SecurityManager配置、web.xml中的shiro过滤器添加与申明顺序。
摘要由CSDN通过智能技术生成

Shiro报错

1、报错详情

org.apache.shiro.UnavailableSecurityManagerException: No SecurityManager accessible to the calling code, either bound to the org.apache.shiro.util.ThreadContext or as a vm static singleton.  This is an invalid application configuration.
    at org.apache.shiro.SecurityUtils.getSecurityManager(SecurityUtils.java:123)
    at org.apache.shiro.subject.Subject$Builder.<init>(Subject.java:627)
    at org.apache.shiro.SecurityUtils.getSubject(SecurityUtils.java:56)

2、报错场景

Struts2+Spring+Hibernate整合Shiro框架报错。
报错位置为UserAction类的login方法中的Subject subject = SecurityUtils.getSubject();
在这里插入图片描述

3、解决办法

①、检查是否配置SecurityManager

SecurityManager配置方式有两种,一种是在spring的xml配置文件中声明。
在这里插入图片描述
另外一种是编写Shiro配置类,使用注解进行申明

@Configuration
public class ShiroConfig {
   

	@Bean
	public ShiroFilterFactoryBean getBean(@Qualifier("securityManager") DefaultWebSecurityManager securityManager)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值