欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解shiro緩存機制

 更新時間:2017年09月20日 09:13:39   作者:動力節(jié)點  
Shiro提供了類似于Spring的Cache抽象,即Shiro本身不實現(xiàn)Cache,但是對Cache進行了又抽象,方便更換不同的底層Cache實現(xiàn)。下面通過實例代碼給大家分享shiro緩存機制,感興趣的朋友一起看看吧

Shiro提供了類似于Spring的Cache抽象,即Shiro本身不實現(xiàn)Cache,但是對Cache進行了又抽象,方便更換不同的底層Cache實現(xiàn)。 

Shiro提供的Cache接口: 

Java代碼  

public interface Cache<K, V> { 
 //根據(jù)Key獲取緩存中的值 
 public V get(K key) throws CacheException; 
 //往緩存中放入key-value,返回緩存中之前的值 
 public V put(K key, V value) throws CacheException; 
 //移除緩存中key對應(yīng)的值,返回該值 
 public V remove(K key) throws CacheException; 
 //清空整個緩存 
 public void clear() throws CacheException; 
 //返回緩存大小 
 public int size(); 
 //獲取緩存中所有的key 
 public Set<K> keys(); 
 //獲取緩存中所有的value 
 public Collection<V> values(); 
} 

Shiro提供的CacheManager接口: 

Java代碼  

public interface CacheManager { 
 //根據(jù)緩存名字獲取一個Cache 
 public <K, V> Cache<K, V> getCache(String name) throws CacheException; 
}

Shiro還提供了CacheManagerAware用于注入CacheManager: 

Java代碼  

public interface CacheManagerAware { 
 //注入CacheManager 
 void setCacheManager(CacheManager cacheManager); 
} 

Shiro內(nèi)部相應(yīng)的組件(DefaultSecurityManager)會自動檢測相應(yīng)的對象(如Realm)是否實現(xiàn)了CacheManagerAware并自動注入相應(yīng)的CacheManager。   

Realm緩存

Shiro提供了CachingRealm,其實現(xiàn)了CacheManagerAware接口,提供了緩存的一些基礎(chǔ)實現(xiàn);另外AuthenticatingRealm及AuthorizingRealm分別提供了對AuthenticationInfo 和AuthorizationInfo信息的緩存。 

ini配置   

Java代碼  

userRealm=com.github.zhangkaitao.shiro.chapter11.realm.UserRealm 
userRealm.credentialsMatcher=$credentialsMatcher 
userRealm.cachingEnabled=true 
userRealm.authenticationCachingEnabled=true 
userRealm.authenticationCacheName=authenticationCache
userRealm.authorizationCachingEnabled=true 
userRealm.authorizationCacheName=authorizationCache 
securityManager.realms=$userRealm 
cacheManager=org.apache.shiro.cache.ehcache.EhCacheManager 
cacheManager.cacheManagerConfigFile=classpath:shiro-ehcache.xml 
securityManager.cacheManager=$cacheManager 

userRealm.cachingEnabled:啟用緩存,默認false;

userRealm.authenticationCachingEnabled:啟用身份驗證緩存,即緩存AuthenticationInfo信息,默認false;

userRealm.authenticationCacheName:緩存AuthenticationInfo信息的緩存名稱;

userRealm. authorizationCachingEnabled:啟用授權(quán)緩存,即緩存AuthorizationInfo信息,默認false;

userRealm. authorizationCacheName:緩存AuthorizationInfo信息的緩存名稱;

cacheManager:緩存管理器,此處使用EhCacheManager,即Ehcache實現(xiàn),需要導入相應(yīng)的Ehcache依賴,請參考pom.xml; 

因為測試用例的關(guān)系,需要將Ehcache的CacheManager改為使用VM單例模式:

this.manager = new net.sf.ehcache.CacheManager(getCacheManagerConfigFileInputStream());

改為

this.manager = net.sf.ehcache.CacheManager.create(getCacheManagerConfigFileInputStream()); 

測試用例 

Java代碼  

@Test 
public void testClearCachedAuthenticationInfo() { 
 login(u1.getUsername(), password); 
 userService.changePassword(u1.getId(), password + "1");
 RealmSecurityManager securityManager = 
  (RealmSecurityManager) SecurityUtils.getSecurityManager(); 
 UserRealm userRealm = (UserRealm) securityManager.getRealms().iterator().next(); 
 userRealm.clearCachedAuthenticationInfo(subject().getPrincipals()); 
 login(u1.getUsername(), password + "1"); 
} 

首先登錄成功(此時會緩存相應(yīng)的AuthenticationInfo),然后修改密碼;此時密碼就變了;接著需要調(diào)用Realm的clearCachedAuthenticationInfo方法清空之前緩存的AuthenticationInfo;否則下次登錄時還會獲取到修改密碼之前的那個AuthenticationInfo; 

Java代碼 

@Test 
public void testClearCachedAuthorizationInfo() { 
 login(u1.getUsername(), password); 
 subject().checkRole(r1.getRole()); 
 userService.correlationRoles(u1.getId(), r2.getId()); 
 RealmSecurityManager securityManager = 
  (RealmSecurityManager) SecurityUtils.getSecurityManager(); 
 UserRealm userRealm = (UserRealm)securityManager.getRealms().iterator().next(); 
 userRealm.clearCachedAuthorizationInfo(subject().getPrincipals()); 
 
 subject().checkRole(r2.getRole()); 
} 

和之前的用例差不多;此處調(diào)用Realm的clearCachedAuthorizationInfo清空之前緩存的AuthorizationInfo; 

另外還有clearCache,其同時調(diào)用clearCachedAuthenticationInfo和clearCachedAuthorizationInfo,清空AuthenticationInfo和AuthorizationInfo。

UserRealm還提供了clearAllCachedAuthorizationInfo、clearAllCachedAuthenticationInfo、clearAllCache,用于清空整個緩存。 

在某些清空下這種方式可能不是最好的選擇,可以考慮直接廢棄Shiro的緩存,然后自己通過如AOP機制實現(xiàn)自己的緩存;可以參考:

https://github.com/zhangkaitao/es/tree/master/web/src/main/java/com/sishuok/es/extra/aop 

另外如果和Spring集成時可以考慮直接使用Spring的Cache抽象,可以考慮使用SpringCacheManagerWrapper,其對Spring Cache進行了包裝,轉(zhuǎn)換為Shiro的CacheManager實現(xiàn):

https://github.com/zhangkaitao/es/blob/master/web/src/main/java/org/apache/shiro/cache/spring/SpringCacheManagerWrapper.java  

Session緩存

當我們設(shè)置了SecurityManager的CacheManager時,如:

Java代碼 

securityManager.cacheManager=$cacheManager 

當我們設(shè)置SessionManager時:

Java代碼  

sessionManager=org.apache.shiro.session.mgt.DefaultSessionManager 
securityManager.sessionManager=$sessionManager 

如securityManager實現(xiàn)了SessionsSecurityManager,其會自動判斷SessionManager是否實現(xiàn)了CacheManagerAware接口,如果實現(xiàn)了會把CacheManager設(shè)置給它。然后sessionManager會判斷相應(yīng)的sessionDAO(如繼承自CachingSessionDAO)是否實現(xiàn)了CacheManagerAware,如果實現(xiàn)了會把CacheManager設(shè)置給它;如第九章的MySessionDAO就是帶緩存的SessionDAO;其會先查緩存,如果找不到才查數(shù)據(jù)庫。 

對于CachingSessionDAO,可以通過如下配置設(shè)置緩存的名稱:

Java代碼  

sessionDAO=com.github.zhangkaitao.shiro.chapter11.session.dao.MySessionDAO 
sessionDAO.activeSessionsCacheName=shiro-activeSessionCache 
activeSessionsCacheName默認就是shiro-activeSessionCache。

總結(jié)

以上所述是小編給大家介紹的shiro緩存機制,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 使用WebUploader實現(xiàn)上傳文件功能(一)

    使用WebUploader實現(xiàn)上傳文件功能(一)

    這篇文章主要為大家詳細介紹了使用WebUploader實現(xiàn)上傳文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Java中的反射機制基本運用詳解

    Java中的反射機制基本運用詳解

    這篇文章主要介紹了Java 反射機制原理與用法,結(jié)合實例形式詳細分析了Java反射機制的相關(guān)概念、原理、基本使用方法及操作注意事項,需要的朋友可以參考下
    2021-08-08
  • 基于Spring AOP的Log收集匯總

    基于Spring AOP的Log收集匯總

    張三針對公司現(xiàn)有日志處理系統(tǒng)的不足,采用了SpringAOP技術(shù)和Redis存儲,設(shè)計并實現(xiàn)了一個性能更高效的日志處理系統(tǒng),該系統(tǒng)通過SpringAOP的切面攔截功能,捕獲方法調(diào)用信息作為日志內(nèi)容,并將其統(tǒng)一格式化后存儲到Redis中
    2024-10-10
  • Jackson自定義序列化反序列化注解加解密字段詳解

    Jackson自定義序列化反序列化注解加解密字段詳解

    這篇文章主要介紹了Jackson自定義序列化反序列化注解加解密字段詳解,一些場景中,數(shù)據(jù)庫字段用于存儲json格式數(shù)據(jù),處于安全的考慮,該json數(shù)據(jù)中,某些敏感信息字段需要做加密存儲,例如身份證號、手機號等,需要的朋友可以參考下
    2023-11-11
  • 使用FileReader采用的默認編碼

    使用FileReader采用的默認編碼

    這篇文章主要介紹了使用FileReader采用的默認編碼,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Springboot2.7+Minio8 實現(xiàn)大文件分片上傳

    Springboot2.7+Minio8 實現(xiàn)大文件分片上傳

    本文主要介紹了Springboot2.7+Minio8 實現(xiàn)大文件分片上傳,通過文件切片上傳,我們能夠提高文件上傳的速度,優(yōu)化用戶體驗,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • Java使用MulticastSocket實現(xiàn)群聊應(yīng)用程序

    Java使用MulticastSocket實現(xiàn)群聊應(yīng)用程序

    這篇文章主要為大家詳細介紹了Java使用MulticastSocket實現(xiàn)群聊應(yīng)用程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 詳談ServiceLoader實現(xiàn)原理

    詳談ServiceLoader實現(xiàn)原理

    下面小編就為大家?guī)硪黄斦凷erviceLoader實現(xiàn)原理。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • JDBC Template基本使用方法詳解

    JDBC Template基本使用方法詳解

    這篇文章主要介紹了JDBC Template基本使用方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • Java基于分治法實現(xiàn)的快速排序算法示例

    Java基于分治法實現(xiàn)的快速排序算法示例

    這篇文章主要介紹了Java基于分治法實現(xiàn)的快速排序算法,結(jié)合實例形式分析了java基于分治法的快速排序相關(guān)實現(xiàn)技巧,代碼中備有較為詳細的注釋說明便于理解,需要的朋友可以參考下
    2017-12-12

最新評論