shiro权限问题.

shiro的权限资源变动的时候. cache中的权限并没有同步更新. 

按理说: 一个用户登录后,会生成一个新的Auth的cache. 然后验证权限的时候,会去cache里面根据用户的身份,拿到具体的perm权限集合.然后看是否含有这个权限. 

但是呢,因为同一个用户登录的时候,生成的key是相同的.所以根据这个key,拿到的就是旧的cache数据.所以,权限就没有及时更新. 

想了个点子: 登录的时候,根据key,把cache里面的这个perm删掉.shiro做了先查缓存,没有再去查数据库的操作.所以.旧的cache删掉之后.需要用到的时候新的cache就会更新上.

试了一下,还真可以.哈哈.

我看的几个源码图片:  太深,再次找不到就亏了.

1

2

解决办法:  

//获取cache缓存.
Cache<Object, AuthorizationInfo> cache = authorizingRealm.getAuthorizationCache();
if (cache != null) {
    cache.remove(simpleAuthenticationInfo.getPrincipals());
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值