Shiro + EHCache 缓存的使用。

JSON 2016-08-26 01:38:22 38474

shiro demo下载

Shiro + SSM(框架) + Freemarker(jsp)讲解的权限控制Demo,还不赶快去下载?




https://www.sojson.com/shiro

我的项目一直在用 Apache   Shiro  ,当然  Spring  有  Security  ,两者差不多作用和性质,我当初在项目选型的时候我选择了  Apache   Shiro  ,居多原因就不说了。每个人有每个人的关注点,所以得出来的结果就不一样,我这并不是说  Shiro  就比 Security  就好。

Shiro + Redis + SpringMVC demo https://www.sojson.com/shiro

我是用 Maven  管理的项目,先上依赖包:

<dependency>
	<artifactId>ehcache-core</artifactId>
	<groupId>net.sf.ehcache</groupId>
	<version>2.5.0</version>
</dependency>
<dependency>
	<groupId>org.apache.shiro</groupId>
	<artifactId>shiro-ehcache</artifactId>
	<version>1.2.2</version>
</dependency>


我现在项目一直是用的  Shiro  Redis  来结合使用,解决的问题有

  1. 用户权限控制。
  2. 分布式部署 Session  共享。
  3. Cookie  管理。
  4. 缓存  管理。
  5. 用户信息、在线用户管理。
  6. ... ...

本文只介绍 Shiro  EHCache  的结合。因为我项目之前用的是 Redis  ,但是项目实际应用没那么多要求,就采用本地 缓存   EHCache  来解决了。

首先有两种方式来创建缓存实列:

一、 Spring  创建方式。

<bean id="cacheManagerFactory"  class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"  
   p:configLocation="classpath:ehcache.xml"></bean>  
   
   <!-- 声明cacheManager -->  
<bean id="shiroEhcacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager"   
   p:cacheManager-ref="cacheManagerFactory" ></bean>

二、Bean创建方式。

<!-- shiro的缓存管理器,然后需要将缓存管理器注入到安全管理其中  -->  
<bean id="shiroEhcacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager">  
       <!--classpath是缓存属性的配置文件  -->  
       <property name="cacheManagerConfigFile" value="classpath:config/ehcache-shiro.xml" />  
</bean>

我先暂且用第二种。

EHCache配置文件说明。

一、 EHCache 配置文件代码。

<?xml version="1.0" encoding="UTF-8"?>
<ehcache updateCheck="false"  name="shirocache">

    <diskStore path="java.io.tmpdir"/>

    <!-- 登录记录缓存 锁定10分钟 -->
    <cache name="passwordRetryCache"
           maxEntriesLocalHeap="2000"
           eternal="false"
           timeToIdleSeconds="3600"
           timeToLiveSeconds="0"
           overflowToDisk="false"
           statistics="true">
    </cache>

    <cache name="authorizationCache"
           maxEntriesLocalHeap="2000"
           eternal="false"
           timeToIdleSeconds="3600"
           timeToLiveSeconds="0"
           overflowToDisk="false"
           statistics="true">
    </cache>

    <cache name="authenticationCache"
           maxEntriesLocalHeap="2000"
           eternal="false"
           timeToIdleSeconds="3600"
           timeToLiveSeconds="0"
           overflowToDisk="false"
           statistics="true">
    </cache>

    <cache name="shiro-activeSessionCache"
           maxEntriesLocalHeap="2000"
           eternal="false"
           timeToIdleSeconds="3600"
           timeToLiveSeconds="0"
           overflowToDisk="false"
           statistics="true">
    </cache>
    <cache name="shiro_cache"
    	   maxElementsInMemory="2000"
           maxEntriesLocalHeap="2000"
           eternal="false"
           timeToIdleSeconds="0"
           timeToLiveSeconds="0"
           maxElementsOnDisk="0"
           overflowToDisk="true"
           memoryStoreEvictionPolicy="FIFO"
           statistics="true">
    </cache>
</ehcache>

二、 EHCache  配置文件解释:

 name Cache的名称,必须是唯一的(ehcache会把这个cache放到HashMap里)
 maxElementsInMemory 内存中保持的对象数量
 maxElementsOnDisk DiskStore中保持的对象数量,默认值为0,表示不限制
 eternal 是否是永恒数据,如果是,则它的超时设置会被忽略
 overflowToDisk 如果内存中数据数量超过maxElementsInMemory限制,是否要缓存到磁盘上
 timeToIdleSeconds 对象空闲时间,指对象在多长时间没有被访问就会失效。只对eternal为false的有效。默认值0,表示一直可以访问
 timeToLiveSeconds 对象存活时间,指对象从创建到失效所需要的时间。只对eternal为false的有效。默认值0,表示一直可以访问
 diskPersistent 是否在磁盘上持久化。指重启jvm后,数据是否有效。默认为false
 diskExpiryThreadIntervalSeconds 对象检测线程运行时间间隔。标识对象状态的线程多长时间运行一次
 diskSpoolBufferSizeMB DiskStore使用的磁盘大小,默认值30MB。每个cache使用各自的DiskStore
 memoryStoreEvictionPolicy 如果内存中数据超过内存限制,向磁盘缓存时的策略。默认值LRU,可选FIFO、LFU

三、 EHCache  管理类。

package net.wenyifan.common.shiro;

import java.util.Collection;
import java.util.HashSet;
import java.util.Set;

import net.wenyifan.common.util.StringUtils;

import org.apache.shiro.cache.Cache;
import org.apache.shiro.cache.CacheException;
import org.apache.shiro.cache.ehcache.EhCacheManager;
import org.apache.shiro.session.Session;
/**
 * 
 * 开发公司:itboy.net<br/>
 * 版权:itboy.net<br/>
 * <p>
 * 
 * EHCache管理
 * 
 * <p>
 * 
 * 区分 责任人 日期    说明<br/>
 * 创建 周柏成 2016年2月16日  <br/>
 * <p>
 * *******
 * <p>
 * @author zhou-baicheng
 * @email  i@itboy.net
 * @version 1.0,2016年2月16日 <br/>
 * 
 */
public class CacheManager<K, V> implements Cache<K, V> {

	private EhCacheManager cacheManager;

	private Cache<K, V> cache = null;
	
	public Cache<K, V> getCache() {
		try {
			if(null == cache){
				cache = cacheManager.getCache("shiro_cache");
			}
		} catch (Exception e) {
			throw new RuntimeException(e);
		}
		return cache;
	}

	@Override
	public void clear() throws CacheException {
		getCache().clear();
	}

	@Override
	public V get(K key) throws CacheException {
		return getCache().get(key);
	}

	@Override
	public Set<K> keys() {
		
		return getCache().keys();
	}

	@Override
	public V put(K key, V value) throws CacheException {
		return getCache().put(key, value);
	}

	@Override
	public V remove(K key) throws CacheException {
		return getCache().remove(key);
	}

	@Override
	public int size() {
		return getCache().size();
	}

	@Override
	public Collection<V> values() {
		return getCache().values();
	}

	public EhCacheManager getCacheManager() {
		return cacheManager;
	}

	public void setCacheManager(EhCacheManager cacheManager) {
		this.cacheManager = cacheManager;
	}

	public void setCache(Cache<K, V> cache) {
		this.cache = cache;
	}

	/**
	 * 获取所有Session
	 * @throws Exception
	 */
	public Collection<Session> AllSession() throws Exception {
                Set<Session> sessions = new HashSet<Session>();
		try {
			//TODO 注意事项:必须此缓存只存储Session,要不造成性能下降
			cache = getCache();
			Collection<V> values = cache.values();
			for (V v : values) {
				if(StringUtils.isNotBlank(v) && v instanceof Session){
					sessions.add((Session)v);
				}
			}
                 } catch (Exception e) {
                    throw e;
                 } 
                 return sessions;
	}
}

shiro  在使用 缓存  存储 Session  或者 存储其他的时候就可以用这个类了。

版权所属:SO JSON在线解析

原文地址:https://www.sojson.com/blog/73.html

转载时必须以链接形式注明原始出处及本声明。

本文主题:

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

关于作者
一个低调而闷骚的男人。
相关文章
Shiro + EHCache 缓存使用
Redis缓存淘汰算法,LRU算法,LRU算法讲解。
又拍云(Upyun)刷新CDN,云存储缓存 —JavaAPI
又拍云(Upyun)CDN、云存储刷新链接缓存,API实例讲解
Shiro教程(八)Shiro Freemarker标签的使用
Shiro教程(九)Shiro JSP标签的使用
Shiro教程(四)Shiro + Redis配置
Springboot 集成 Ehcache 代码讲解
Shiro教程(五)Shiro + Redis实现
Shiro 教程,Shiro教程0.2 下载,Shiro功能修复与升级说明。
最新文章
Flink 在又拍云日志批处理中的实践 5337
个推异常值检测和实战应用-又拍云 946
TCP 和 UDP协议详细讲解,优缺点分析讲解 6572
URL中乱七八糟的字符讲解,来源以及如何解决 4244
HTTP/3 来了,您真的了解它么? 5350
技术选型:为什么批处理我们却选择了Flink 1867
这些表情包你有吗?一起来 Battle 啊 2859
当我谈 HTTP 时,我谈些什么? 11167
新浪短链(t.cn)最新申请官方API的方法讲解。 68114
QUIC / HTTP3 协议详细分析讲解 8932
最热文章
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 646009
最新MyEclipse8.5注册码,有效期到2020年 (已经更新) 592274
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 492699
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 481164
Jackson 时间格式化,时间注解 @JsonFormat 用法、时差问题说明 470194
Elasticsearch教程(四) elasticsearch head 插件安装和使用 418218
免费天气API,天气JSON API,不限次数获取十五天的天气预报 226891
Java 信任所有SSL证书,HTTPS请求抛错,忽略证书请求完美解决 212680
谈谈斐讯路由器劫持,你用斐讯路由器,你需要知道的事情 199311
Elasticsearch教程(一),全程直播(小白级别) 185533
支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

查看我的收藏

正在加载... ...