
org.crazycake.shiro.common.WorkAloneRedisManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of shiro-redis Show documentation
Show all versions of shiro-redis Show documentation
shiro only provide the support of ehcache and concurrentHashMap. Here is an implement of redis cache can be used by shiro. Hope it will help you!
The newest version!
package org.crazycake.shiro.common;
import org.crazycake.shiro.IRedisManager;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.ScanParams;
import redis.clients.jedis.ScanResult;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
/**
* Abstract class of RedisManager.
*/
public abstract class WorkAloneRedisManager implements IRedisManager {
/**
* We are going to operate redis by acquiring Jedis object.
* The subclass should realizes the way to get Jedis objects by implement the getJedis().
* @return Jedis
*/
protected abstract Jedis getJedis();
/**
* Default value of count.
*/
protected static final int DEFAULT_COUNT = 100;
/**
* The number of elements returned at every iteration.
*/
private int count = DEFAULT_COUNT;
/**
* JedisPoolConfig used to initialize JedisPool.
*/
private JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
/**
* get value from redis
* @param key key
* @return value
*/
@Override
public byte[] get(byte[] key) {
if (key == null) {
return null;
}
byte[] value;
Jedis jedis = getJedis();
try {
value = jedis.get(key);
} finally {
jedis.close();
}
return value;
}
/**
* set
* @param key key
* @param value value
* @param expireTime expire time in second
* @return value
*/
@Override
public byte[] set(byte[] key, byte[] value, int expireTime) {
if (key == null) {
return null;
}
Jedis jedis = getJedis();
try {
jedis.set(key, value);
// -1 and 0 is not a valid expire time in Jedis
if (expireTime > 0) {
jedis.expire(key, expireTime);
}
} finally {
jedis.close();
}
return value;
}
/**
* Delete a key-value pair.
* @param key key
*/
@Override
public void del(byte[] key) {
if (key == null) {
return;
}
Jedis jedis = getJedis();
try {
jedis.del(key);
} finally {
jedis.close();
}
}
/**
* Return the size of redis db.
* @param pattern key pattern
* @return key-value size
*/
@Override
public Long dbSize(byte[] pattern) {
long dbSize = 0L;
Jedis jedis = getJedis();
try {
ScanParams params = new ScanParams();
params.count(count);
params.match(pattern);
byte[] cursor = ScanParams.SCAN_POINTER_START_BINARY;
ScanResult scanResult;
do {
scanResult = jedis.scan(cursor, params);
List results = scanResult.getResult();
for (byte[] result : results) {
dbSize++;
}
cursor = scanResult.getCursorAsBytes();
} while (scanResult.getCursor().compareTo(ScanParams.SCAN_POINTER_START) > 0);
} finally {
jedis.close();
}
return dbSize;
}
/**
* Return all the keys of Redis db. Filtered by pattern.
* @param pattern key pattern
* @return key set
*/
public Set keys(byte[] pattern) {
Set keys = new HashSet();
Jedis jedis = getJedis();
try {
ScanParams params = new ScanParams();
params.count(count);
params.match(pattern);
byte[] cursor = ScanParams.SCAN_POINTER_START_BINARY;
ScanResult scanResult;
do {
scanResult = jedis.scan(cursor, params);
keys.addAll(scanResult.getResult());
cursor = scanResult.getCursorAsBytes();
} while (scanResult.getCursor().compareTo(ScanParams.SCAN_POINTER_START) > 0);
} finally {
jedis.close();
}
return keys;
}
public int getCount() {
return count;
}
public void setCount(int count) {
this.count = count;
}
public JedisPoolConfig getJedisPoolConfig() {
return jedisPoolConfig;
}
public void setJedisPoolConfig(JedisPoolConfig jedisPoolConfig) {
this.jedisPoolConfig = jedisPoolConfig;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy