zoukankan      html  css  js  c++  java
  • springboot整合shiro之缓存理解

    缓存的作用:用于缓存认证信息和授权信息,不用每次都去数据库里查询数据,而是从缓存中获取。

    当我们在shiro过滤器对一些url进行权限,角色授权时,如 filterMap.put("/user/add", "perms[user:add]");

    程序将自动的去数据库中查询所需要的角色权限信息,一旦我们的菜单和按钮上写入的控制太多,那么将对应查询很多次数据库。

    1:授权认证:

    (1)当第一次访问授权时,会调用自定义Realm的获取授权数据的方法,从数据库中查询授权数据,并将其以登录者的Principal为键,存储在缓存中。以后的每次访问授权,就直接从缓存中获取,而不再从数据库中获取。

    2:清空缓存的时机:

    (1)当退出登录时,会调用清空缓存的方法,将以当前登陆者的Principal为键的缓存中的授权数据清空掉。

    (2)如果修改了用户的权限,而用户不退出系统,修改的权限不会生效,此时需要手动调用realm的clearCache方法清除缓存,待下次访问授权数据时,重新从数据库中获取,并存储在缓存中。

    (3)用户未退出登录的情况下,关闭浏览器,也清空缓存。

    3:缓存方式:

    (1)shiro整合ehcache缓存

    (2)shiro整合redis缓存

  • 相关阅读:
    网络状态码含义——(比如204,304, 404, 504,502)
    Vue两个简易代替vuex的方法(eventBus,observable)
    单页面首屏加载慢解决方案
    前端监控和前端埋点
    ES5 和 ES6的继承
    mysql 隔离级别
    mysql 事务
    Seata
    Sentinel Dashboard 部署
    java 垃圾回器
  • 原文地址:https://www.cnblogs.com/chong-zuo3322/p/12448692.html
Copyright © 2011-2022 走看看