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中调用,进行清理权限信息。

  • 相关阅读:
    SpringBoot页面访问处理
    体验SpringBoot
    体验SpringBoot
    Scala基础
    修改容器配置使其永久生效
    [徐培成系列实战课程]docker篇
    v1.0.2-2017.04.26
    修改容器的hosts文件
    配置spark集群
    配置docker容器上ssh无密登录
  • 原文地址:https://www.cnblogs.com/adam1991/p/8283991.html
Copyright © 2011-2022 走看看