SpringMVC配置错误页后, Shiro报错No SecurityManager accessible to the calling code...

博客内容讲述了在SpringMVC中配置错误页后,遇到Shiro报错'No SecurityManager accessible to the calling code...'的问题。问题的根本原因是web.xml中缺少了Shiro拦截器的配置,解决方案是确保所有404、500等错误页面请求都通过Shiro拦截器,以避免在无SecurityManager的情况下尝试获取Subject。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Root Cause:

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.

网上搜罗来的解释说是web.xml少了这一段, 但是我有:

<!-- 配置shiro的核心拦截器 -->
    <filter>
        <filter-name>shiroFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>shiroFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

后来发现是还少了几行, 完整体应该是:

<!-- 配置shiro的核心拦截器 -->
    <filter>
        <filter-name>shiroFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>shiroFilter</filter-name>
        <url-pattern>/*</url-pattern>
        <dispatcher>REQUEST</dispatcher>
        <dispatcher>FORWARD</dispatcher>
        <dispatcher>INCLUDE</dispatcher>
        <dispatcher>ERROR</dispatcher>
    </filter-mapping>

表示这4种都要经过shiro拦截器。我之前配置的404页面里回去访问shiro的SecurityUtils.getSubject(),若error不被拦截, 则这个请求是无法获取Subject的, 因此报错

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值