shiro注解不生效(表象)

本文通过实际案例解析了Apache Shiro框架中@RequiresPermissions注解不生效的原因及解决方案,涉及注解启用配置、权限匹配规则等内容。

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

连续被折磨三天,shiro的@RequiresPermissions注解就是感觉不到生效,找各种博文、帖子也解决不了,最后逼着对shiro断点观察,终于找到问题根源...


在网上找资料,一般注解不生效,主要有两个原因:

1、没有启用shiro注解功能。而启用该功能主要有如下两种方式:

①、使用<aop:config/>

<!-- Shiro生命周期处理器-->
<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/>
<aop:config proxy-target-class="true"></aop:config>
<bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
     <property name="securityManager" ref="securityManager"/>
</bean>

②、使用DefaultAdvisorAutoProxyCreator

<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/>
 <!-- 启用shiro 注解 -->
<bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"  depends-on="lifecycleBeanPostProcessor"/>
<bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
     <property name="securityManager" ref="securityManager"/>
</bean>

2、需要将以上开启shiro注解功能放在spring-mvc.xml文件中。

说明:这种情况我没遇上,我的也没放进改配置文件中,我是直接放在spring-shiro.xml文件中,然后在web.xml的context-param中引入的。


但是,我这边并不是这两种情况,试了各种情况,发现都不好使,最后在org.apache.shiro.authz.aop.PermissionAnnotationHandler断点跟进,发现确实进去了,说明@RequiresPermissions确实生效,可为什么我配置一个错误的权限值(@RequiresPermissions(operative:manager:itemlist111111),正确的是@RequiresPermissions(operative:manager:itemlist))还是报错呢?最后发现受shiro的匹配规则影响,因为我在系统中已经有了一个operative:manager权限,所以在末尾加权限项会让shiro判断已经拥有该权限。好吧,终于找到问题根源,然后我将已经存在的operative:manager改为operative:manager:manager就全部ok了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值