Shiro + EHCache 缓存的使用。

soゝso 2016-08-26 01:38:22 18143
分享到:

shiro demo下载

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




http://www.sojson.com/shiro

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

Shiro + Redis + SpringMVC demo http://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  [email protected]
 * @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  或者 存储其他的时候就可以用这个类了。

关于作者
目前就职于国内某电商平台公司打杂。。
相关文章
Redis缓存淘汰算法,LRU算法,LRU算法讲解。
Shiro教程(八)Shiro Freemarker标签的使用
Shiro教程(九)Shiro JSP标签的使用
Shiro教程(五)Shiro + Redis实现
Shiro教程(六)Shiro整体的配置文件
Shiro教程(一)Shiro 是什么?Shiro的简单介绍。
Java 解析JSON,JSON-LIB jar包下载和使用
Shiro教程(二)Maven管理Shrio Jar包
Shiro教程(三)Shiro web.xml中Filter配置,配置注意事项
Shiro教程(十一)Shiro 控制并发登录人数限制实现,登录踢出实现
最新文章
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 38754
JS解密,JavaScript 解密,任何JS加密都能100%解密,以及JS 加密讲解 66
阿里云DNS 解析讲解,SEO配置搜索引擎线路解析 41
百度秒收录教程,怎么做到百度秒收入你的页面,SEO 教程 89
CDN 请求返回 connection reset by peer,被拦截请求解决方案 33
Google AdSense 申请技巧,谷歌广告申请通不过教程 66
Mac 安装 JMeter,JMeter 下载,JMeter Http 压力测试【图解】 45
支付宝吱口令自动复制脚本,自动复制 JavaScript 代码介绍 866
谈谈这次对 SOJSON 的改版 146
Java 计算2个时间相差多少年,多少个月,多少天的几种方式 484
最热文章
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 38754
Elasticsearch教程(四) elasticsearch head 插件安装和使用 108910
Elasticsearch教程(六) elasticsearch Client创建 73264
Elasticsearch教程(八) elasticsearch delete 删除数据(Java) 70727
Elasticsearch教程(二),IK分词器安装 67441
Elasticsearch教程(三),IK分词器安装 (极速版) 54071
Elasticsearch教程(五) elasticsearch Mapping的创建 51534
Elasticsearch教程(一),全程直播(小白级别) 51227
Elasticsearch教程(七) elasticsearch Insert 插入数据(Java) 47703
Elasticsearch权威指南-中文.pdf,Elasticsearch 中文文档下载 40877

骚码加入我们 / 千人QQ群:259217951

入群需要5元,如果没有QQ钱包,可以先Alipay、微信,赞助然后加群主拉进。

二维码生成 来自 >> 二维码生成器

支付扫码

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

正在加载... ...