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

  • 相关阅读:
    java痛苦学习之路[十]--日常问题汇总
    我有回来了
    LeetCode[Array]----3Sum
    在Visual Stdio 2012中编译执行JM18.6的方法
    Android沉浸式状态栏兼容4.4手机的实现
    HTML5学习笔记(九):选择器详解
    HTML5学习笔记(八):CSS定位
    HTML5学习笔记(七):CSS盒子模型
    HTML5学习笔记(六):CSS基本样式
    HTML5学习笔记(五):CSS基础
  • 原文地址:https://www.cnblogs.com/adam1991/p/8283991.html
Copyright © 2020-2023  润新知