zoukankan      html  css  js  c++  java
  • SSM+Apache shiro--ehcache缓存清理

    使用ehache进行缓存,可以再登陆认证成功后缓存认证授权及权限信息,但是用户退出时,该用户对应的权限信息不能进行实时更新,所以要求在用户退出系统时可以清理其对应的权限信息缓存。

    在配置ehcache缓存是我们配置了myshiroCache,并在myrealm中指定了权限缓存的名字,所以在用户退出时就可以通过cacheManager及缓存名字获取该信息,并清理,实现退出系统时清理权限信息。

    package com.copsec.railway.im.util;
    import org.apache.log4j.Logger;
    import org.apache.shiro.SecurityUtils;
    import org.apache.shiro.cache.Cache;
    import org.apache.shiro.cache.CacheManager;
    import org.apache.shiro.subject.SimplePrincipalCollection;
    import org.apache.shiro.subject.Subject;public class ShiroAuthorizationHelper {
    
        private static CacheManager cacheManager;
    
        private static Logger logger = Logger.getLogger(ShiroAuthorizationHelper.class);
    
        /**
         * 清除用户的权限
         * 
         *
         * @param principal 登陆用户对应的principal对象
         */
        public static void clearAuthorizationInfo(SimplePrincipalCollection principal) {
            logger.info("clear the user: " + principal.toString() + "'s authorizationInfo");
            Cache<Object, Object> cache = cacheManager.getCache("myShiroCache");
            cache.remove(principal);
        }
    
        /**
         * 清除当前用户的权限
         */
        public static void clearAuthorizationInfo() {
            if (SecurityUtils.getSubject().isAuthenticated()) {
                Subject subject = SecurityUtils.getSubject();
                String username = subject.getPrincipal().toString();
                String realmName = subject.getPrincipals().getRealmNames().iterator().next();
                SimplePrincipalCollection principalCollection = new SimplePrincipalCollection(username, realmName);
                logger.debug("get user principalCollection :"+principalCollection);
                // 调用清理用户权限
                clearAuthorizationInfo(principalCollection);
            }
        }
    
        /**
         * 由Spring bean将对象注入
         * @param cacheManager
         */
        public static void setCacheManager(CacheManager cacheManager) {
            
            ShiroAuthorizationHelper.cacheManager = cacheManager;
        }
    
    
    }

    完成后即可在logout controller中调用,进行清理权限信息。

  • 相关阅读:
    Metinfo 5.x 管理员密码重置漏洞
    【CVE-2018-11116】openwrt rpcd 配置文件错误导致访问控制失效
    openwrt-rpcd服务ACL配置错误风险分析
    黑客基础知识
    渗透测试(漏洞利用)
    Niagara物联网框架机制二(笔记)
    基于kali linux无线网络渗透测试
    渗透测试(漏洞扫描)
    Workbench热水泵系统
    Niagara物联网框架机制一(笔记)
  • 原文地址:https://www.cnblogs.com/adam1991/p/8283991.html
Copyright © 2011-2022 走看看