• Shiro 修改权限,刷新权限


    shiro 访问鉴权:Realm

    AuthorizingRealm->doGetAuthorizationInfo
    doGetAuthorizationInfo
    
    protected abstract AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals)
    
    Retrieves the AuthorizationInfo for the given principals from the underlying data store. When returning an instance from this method, you might want to consider using an instance of SimpleAuthorizationInfo, as it is suitable in most cases.
    
    Parameters:
    
    principals - the primary identifying principals of the AuthorizationInfo that should be retrieved.
    
    Returns:
    
    the AuthorizationInfo associated with this principals.
    
    See Also:
    
    SimpleAuthorizationInfo

    shiro 需要访问数据库查询权限信息。

    结合缓存框架,第一次查询权限信息后缓存,在缓存生存期内,访问鉴权使用缓存中的权限信息。

    优点:减少数据库查询,缓存快速获取,提升了每次访问效率,减少了数据库压力。

    缺点:涉及权限修改,生效会有一个最大缓存生存周期的间隔期。

    解决方法:

    每次修改权限后,调用 clearCachedAuthorizationInfo 刷新权限:

    clearCachedAuthorizationInfo
    
    protected void clearCachedAuthorizationInfo(PrincipalCollection principals)
    
    Clears out the AuthorizationInfo cache entry for the specified account.
    
    This method is provided as a convenience to subclasses so they can invalidate a cache entry when they change an account's authorization data (add/remove roles or permissions) during runtime. Because an account's AuthorizationInfo can be cached, there needs to be a way to invalidate the cache for only that account so that subsequent authorization operations don't used the (old) cached value if account data changes.
    
    
    
    After this method is called, the next authorization check for that same account will result in a call to getAuthorizationInfo, and the resulting return value will be cached before being returned so it can be reused for later authorization checks.
    
    
    
    If you wish to clear out all associated cached data (and not just authorization data), use the CachingRealm.clearCache(org.apache.shiro.subject.PrincipalCollection) method instead (which will in turn call this method by default).
    
    
    
    Parameters:
    
    principals - the principals of the account for which to clear the cached AuthorizationInfo.



    示例项目:https://github.com/windwant/spring-dubbo-service

    https://github.com/windwant/spring-boot-service

  • 相关阅读:
    创建100个文件,并对每个文件赋值
    vsftpd服务程序的三种认证模式
    slf4j打印日志必须的三个依赖包
    MySql镜像安装
    java子类调用父类构造器函数
    shell脚本批量调用接口
    go语言生成可执行文件
    linux通过VMware和主机相连连接互联网
    yum源配置
    vmware上安装linux过程记录
  • 原文地址:https://www.cnblogs.com/niejunlei/p/8383895.html
Copyright © 2020-2023  润新知