Redis-RedisUtils工具类

概述:

       本文不对redis再做相关详细的介绍,有关redis的相关基础知识及安装,数据结构,命令等请参考菜鸟教程中redis的相关介绍,通俗易懂。本篇文章仅仅针对实际中的开发对redis的操作进行封装。该工具类在jedis对redis操作封装的基础上近一步进行封装,在实际的开发中直接调用即可。由于方法太多,过于详细,在实际项目中可截取部分方法进行使用。由于该工具类中在加载redis连接池的时候需要读取redisConfig.properties文件所以需要用到PropertiesUtils.java工具类。Redis中存储及获取Java对象时需要对对象进行序列化和反序列化,所以还需一个java序列化和反序列化的工具类SerializeUtils.java。各种工具类齐备之后就可以直接调用RedisUtils.java中的方法进行操作Redis。

       菜鸟教程网址:http://www.runoob.com/redis/redis-tutorial.html

1、RedisUtils.java如下:

package com.jwang.ssmxml.common.redis;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.StringUtils;

import com.jwang.ssmxml.common.util.PropertiesUtils;
import com.jwang.ssmxml.common.util.SerializeUtils;

import redis.clients.jedis.BinaryClient.LIST_POSITION;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.util.SafeEncoder;

/**
 * redis操作工具类
 * @author jwang
 *
 */
public class RedisUtils 
{
    private static Logger logger = LoggerFactory.getLogger(RedisUtils.class);
    
    //获取连接参数
    private static final String PROPETIES_PATH = "config/redisConfig.properties";
	
	private static final Properties PROP = PropertiesUtils.getProperties(PROPETIES_PATH);
	
	private static final String REDIS_ADDR = PROP.getProperty("redis.ip");
	
	private static final String REDIS_PORT = PROP.getProperty("redis.port");
	
	private static final String REDIS_MAXACTIVE = PROP.getProperty("redis.pool.maxActive");
	
	private static final String REDIS_MAXIDLE = PROP.getProperty("redis.pool.maxIdle");
	
	private static final String REDIS_MAXWAIt = PROP.getProperty("redis.pool.maxWait");
	
	private static final String REDIS_TIMEOUT = PROP.getProperty("redis.timeout");
	
	private static final String REDIS_PASSWORD = PROP.getProperty("redis.password");
	
	private static final String REDIS_TESTONBORROW = PROP.getProperty("redis.pool.testOnBorrow");
    
	private static JedisPool jedisPool = null;
    
	//初始化redis连接池
    static
    {
        try 
        {
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxTotal(Integer.parseInt(REDIS_MAXACTIVE));
            config.setMaxIdle(Integer.parseInt(REDIS_MAXIDLE));
            config.setMaxWaitMillis(Integer.parseInt(REDIS_MAXWAIt));
            config.setTestOnBorrow(Boolean.parseBoolean(REDIS_TESTONBORROW));
            jedisPool = new JedisPool(config, REDIS_ADDR, Integer.parseInt(REDIS_PORT), 
            		Integer.parseInt(REDIS_TIMEOUT), REDIS_PASSWORD);
        }
        catch (Exception e)
        {
        	logger.error("Jedis pool create fail!!!");
            e.printStackTrace();
        }
    }

    /**
     * 获取Jedis实例
     * @return
     */
    public static synchronized Jedis getJedis() 
    {
        try
        {
            if (jedisPool != null) 
            {
                Jedis resource = jedisPool.getResource();
                return resource;
            } 
            else 
            {
                return null;
            }
        }
        catch (Exception e)
        {
        	logger.error("Jedis get fail!!!");
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 释放jedis资源
     * @param jedis
     */
    public static void closeResource(final Jedis jedis)
    {
        if (jedis != null)
        {
        	jedis.close();
        }
    }

    /**
     * 获取redis键值-object
     * 
     * @param key
     * @return
     */
    public static Object getObject(String key) 
    {
        Jedis jedis = null;
        try 
        {
            jedis = jedisPool.getResource();
            byte[] bytes = jedis.get(key.getBytes());
            if(!StringUtils.isEmpty(bytes))
            {
                return SerializeUtils.unserialize(bytes);
            }
        }
        catch (Exception e) 
        {
            logger.error("getObject获取redis键值异常:key=" + key + " cause:" + e.getMessage());
        } 
        finally
        {
            jedis.close();
        }
        return null;
    }

    /**
     * 设置redis-object
     * @param key
     * @param value
     * @return
     */
    public static String setObject(String key, Object value) 
    {
        Jedis jedis = null;
        try
        {
            jedis = jedisPool.getResource();
            return jedis.set(key.getBytes(), SerializeUtils.serialize(value));
        }
        catch (Exception e)
        {
            logger.error("setObject设置redis键值异常:key=" + key + " value=" + value + " cause:" + e.getMessage());
            return null;
        } 
        finally
        {
            if(jedis != null)
            {
                jedis.close();
            }
        }
    }

    /**
     * 添加key-value及设置过期时间
     * @param key
     * @param value
     * @param expiretime
     * @return
     */
    public String setObject(String key, Object value,int expiretime)
    {
        String result = "";
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            result = jedis.set(key.getBytes(), SerializeUtils.serialize(value));
            if(result.equals("OK")) 
            {
                jedis.expire(key.getBytes(), expiretime);
            }
            return result;
        }
        catch (Exception e)
        {
            logger.error("setObject设置redis键值异常:key=" + key + " value=" + value + " cause:" + e.getMessage());
        } 
        finally 
        {
            if(jedis != null)
            {
                jedis.close();
            }
        }
        return result;
    }

    /**
     * 删除key
     * @param key
     * @return
     */
    public Long delkeyObject(String key) 
    {
        Jedis jedis = null;
        try 
        {
            jedis = jedisPool.getResource();
            return jedis.del(key.getBytes());
        }
        catch(Exception e) 
        {
            e.printStackTrace();
            return null;
        }
        finally{
            if(jedis != null)
            {
                jedis.close();
            }
        }
    }

    /**
     * 判断某个key是否存在
     * @param key
     * @return
     */
    public Boolean existsObject(String key) 
    {
        Jedis jedis = null;
        try
        {
            jedis = jedisPool.getResource();
            return jedis.exists(key.getBytes());
        }
        catch(Exception e) 
        {
            e.printStackTrace();
            return null;
        }
        finally
        {
            if(jedis != null)
            {
                jedis.close();
            }
        }
    }
    
    /** 
     * 清空所有key 
     */  
    public String flushAll()
    {  
        Jedis jedis = getJedis();  
        String stata = jedis.flushAll();  
        closeResource(jedis);
        return stata;  
    }  

    /** 
     * 更改key 
     * @param String oldkey 
     * @param String newkey 
     * @return 状态码 
     * 
     */  
    public String rename(String oldkey,String newkey) 
    {  
        Jedis jedis = getJedis();  
        String status = jedis.rename(oldkey.getBytes(), newkey.getBytes());  
        closeResource(jedis);  
        return status;  
    }  
    
    /** 
     * 设置key的过期时间,以秒为单位 
     * @param String key 
     * @param 时间,以秒为单位 
     * @return 影响的记录数 
     *
     */  
    public long expired(String key, int seconds) 
    {  
        Jedis jedis = getJedis();  
        long count = jedis.expire(key, seconds);  
        closeResource(jedis);  
        return count;  
    }  
    
    /** 
     * 取消对key过期时间的设置 
     * @param key 
     * @return 影响的记录数 
     */  
    public long persist(String key)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.persist(key);  
        closeResource(jedis);   
        return count;  
    }  
    
    /** 
     * 删除keys对应的记录,可以是多个key 
     * @param String  ... keys 
     * @return 删除的记录数 
     * */  
    public long del(String... keys)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.del(keys);  
        closeResource(jedis);  
        return count;  
    }  
    
    /** 
     * 删除keys对应的记录,可以是多个key 
     * @param String .. keys 
     * @return 删除的记录数 
     */  
    public long del(byte[]... keys)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.del(keys);  
        closeResource(jedis);  
        return count;  
    }  
    
    /** 
     * 返回指定key存储的类型 
     * @param String key 
     * @return String string|list|set|zset|hash 
     */  
    public String type(String key)
    {  
        Jedis jedis=getJedis();    
        String type = jedis.type(key);   
        closeResource(jedis);  
        return type;  
    }  
    
    /** 
     * 查找所有匹配给定的模式的键 
     * @param String  key的表达式,*表示多个,?表示一个 
     */  
    public Set<String> keys(String pattern)
    {  
        Jedis jedis = getJedis();  
        Set<String> set = jedis.keys(pattern);  
        closeResource(jedis);  
        return set;  
    }  
     
    //********************Sets*****************//  
    
    /** 
     * 向Set添加一条记录,如果member已存在返回0,否则返回1 
     * @param String  key 
     * @param String member 
     * @return 操作码,0或1 
     */  
    public long setAdd(String key, String member)
    {  
        Jedis jedis = getJedis();  
        long status = jedis.sadd(key, member);  
        closeResource(jedis);  
        return status;  
    }  

    public long setAdd(byte[] key, byte[] member)
    {  
        Jedis jedis = getJedis();  
        long status = jedis.sadd(key, member);  
        closeResource(jedis);  
        return status;  
    }  

    /** 
     * 获取给定key的set中元素个数 
     * @param String key 
     * @return 元素个数 
     */  
    public long scard(String key)
    {  
        Jedis jedis = getJedis();   
        long len = jedis.scard(key);  
        closeResource(jedis);  
        return len;  
    }  

    /** 
     * 返回从第一组和所有的给定集合之间的差异的成员 
     * @param String ... keys 
     * @return 差异的成员集合 
     */  
    public Set<String> sdiff(String... keys) 
    {  
        Jedis jedis = getJedis();  
        Set<String> set = jedis.sdiff(keys);  
        closeResource(jedis);  
        return set;  
    }  

    /** 
     * 这个命令等于sdiff,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 
     * @param String newkey 新结果集的key 
     * @param String ... keys 比较的集合 
     * @return 新集合中的记录数 
     */  
    public long sdiffstore(String newkey, String... keys) 
    {  
        Jedis jedis = getJedis();  
        long s = jedis.sdiffstore(newkey, keys);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 返回给定集合交集的成员,如果其中一个集合为不存在或为空,则返回空Set 
     * @param String ... keys 
     * @return 交集成员的集合 
     */  
    public Set<String> sinter(String... keys) 
    {  
        Jedis jedis = getJedis();  
        Set<String> set = jedis.sinter(keys);  
        closeResource(jedis);  
        return set;  
    }  

    /** 
     * 这个命令等于sinter,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 
     * @param String  newkey 新结果集的key 
     * @param String ... keys 比较的集合 
     * @return 新集合中的记录数 
     */  
    public long sinterstore(String newkey, String... keys)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.sinterstore(newkey, keys);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 确定一个给定的值是否存在 
     * @param String  key 
     * @param String member 要判断的值 
     * @return 存在返回1,不存在返回0 
     */  
    public boolean sismember(String key, String member)
    {  
        Jedis jedis = getJedis();   
        boolean status = jedis.sismember(key, member);  
        closeResource(jedis); 
        return status;  
    }  

    /** 
     * 返回集合中的所有成员 
     * @param String  key 
     * @return 成员集合 
     * */  
    public Set<String> smembers(String key) 
    {  
        Jedis jedis = getJedis();   
        Set<String> set = jedis.smembers(key);  
        closeResource(jedis); 
        return set;  
    }  

    public Set<byte[]> smembers(byte[] key) 
    {  
        Jedis jedis = getJedis();    
        Set<byte[]> set = jedis.smembers(key);  
        closeResource(jedis);  
        return set;  
    }  

    /** 
     * 将成员从源集合移出放入目标集合 
     * 如果源集合不存在或不包哈指定成员,不进行任何操作,返回0
     * 否则该成员从源集合上删除,并添加到目标集合,如果目标集合中成员已存在,则只在源集合进行删除 
     * @param String  srckey 源集合 
     * @param String dstkey 目标集合 
     * @param String member 源集合中的成员 
     * @return 状态码,1成功,0失败 
     */  
    public long smove(String srckey, String dstkey, String member) 
    {  
        Jedis jedis = getJedis();  
        long s = jedis.smove(srckey, dstkey, member);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 从集合中删除成员 
     * @param String  key 
     * @return 被删除的成员 
     */  
    public String spop(String key) 
    {  
        Jedis jedis = getJedis();  
        String s = jedis.spop(key);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 从集合中删除指定成员 
     * @param String key 
     * @param String  member 要删除的成员 
     * @return 状态码,成功返回1,成员不存在返回0 
     */  
    public long srem(String key, String member)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.srem(key, member);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 合并多个集合并返回合并后的结果,合并后的结果集合并不保存
     * @param String  ... keys 
     * @return 合并后的结果集合 
     * @see sunionstore 
     * */  
    public Set<String> sunion(String... keys) 
    {  
        Jedis jedis = getJedis();  
        Set<String> set = jedis.sunion(keys);  
        closeResource(jedis);  
        return set;  
    }  

    /** 
     * 合并多个集合并将合并后的结果集保存在指定的新集合中,如果新集合已经存在则覆盖 
     * @param String  newkey 新集合的key 
     * @param String ... keys 要合并的集合 
     */  
    public long sunionstore(String newkey, String... keys)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.sunionstore(newkey, keys);  
        closeResource(jedis);  
        return s;  
    }  

    //********************SortSet*****************// 

    /** 
     * 向集合中增加一条记录,如果这个值已存在,这个值对应的权重将被置为新的权重 
     * @param String  key 
     * @param double score 权重 
     * @param String  member 要加入的值, 
     * @return 状态码 1成功,0已存在member的值 
     */  
    public long zadd(String key, double score, String member)
    {  
        Jedis jedis = getJedis();  
        long status = jedis.zadd(key, score, member);  
        closeResource(jedis);  
        return status;  
    }  

    /** 
     * 获取集合中元素的数量 
     * @param String  key 
     * @return 如果返回0则集合不存在 
     */  
    public long zcard(String key)
    {  
        Jedis jedis = getJedis();  
        long len = jedis.zcard(key);  
        closeResource(jedis); 
        return len;  
    }  

    /** 
     * 获取指定权重区间内集合的数量 
     * @param String key 
     * @param double min 最小排序位置 
     * @param double max 最大排序位置 
     * */  
    public long zcount(String key, double min, double max) 
    {  
        Jedis jedis = getJedis();  
        long len = jedis.zcount(key, min, max);  
        closeResource(jedis); 
        return len;  
    }  

    /** 
     * 获得set的长度 
     *  
     * @param key 
     * @return 
     */  
    public long zlength(String key) 
    {  
        long len = 0;  
        Set<String> set = zrange(key, 0, -1);  
        len = set.size();  
        return len;  
    }  

    /** 
     * 权重增加给定值,如果给定的member已存在 
     * @param String  key 
     * @param double score 要增的权重 
     * @param String  member 要插入的值 
     * @return 增后的权重 
     * */  
    public double zincrby(String key, double score, String member) 
    {  
        Jedis jedis = getJedis();  
        double s = jedis.zincrby(key, score, member);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 返回指定位置的集合元素,0为第一个元素,-1为最后一个元素 
     * @param String key 
     * @param int start 开始位置(包含) 
     * @param int end 结束位置(包含) 
     * @return Set<String> 
     * */  
    public Set<String> zrange(String key, int start, int end)
    {  
        Jedis jedis = getJedis();   
        Set<String> set = jedis.zrange(key, start, end);  
        closeResource(jedis); 
        return set;  
    }  

    /** 
     * 返回指定权重区间的元素集合 
     * @param String key 
     * @param double min 上限权重 
     * @param double max 下限权重 
     * @return Set<String> 
     * */  
    public Set<String> zrangeByScore(String key, double min, double max)
    {  
        Jedis jedis = getJedis();   
        Set<String> set = jedis.zrangeByScore(key, min, max);  
        closeResource(jedis); 
        return set;  
    }  

    /** 
     * 获取指定值在集合中的位置,集合排序从低到高 
     * @see zrevrank 
     * @param String key 
     * @param String member 
     * @return long 位置 
     * */  
    public long zrank(String key, String member)
    {  
        Jedis jedis = getJedis();   
        long index = jedis.zrank(key, member);  
        closeResource(jedis); 
        return index;  
    }  

    /** 
     * 获取指定值在集合中的位置,集合排序从高到低 
     * @see zrank 
     * @param String key 
     * @param String member 
     * @return long 位置 
     * */  
    public long zrevrank(String key, String member)
    {  
        Jedis jedis = getJedis();   
        long index = jedis.zrevrank(key, member);  
        closeResource(jedis); 
        return index;  
    }  

    /** 
     * 从集合中删除成员 
     * @param String key 
     * @param String member  
     * @return 返回1成功 
     * */  
    public long zrem(String key, String member)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.zrem(key, member);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 删除 
     * @param key 
     * @return 
     */  
    public long zrem(String key) 
    {  
        Jedis jedis = getJedis();  
        long s = jedis.del(key);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 删除给定位置区间的元素 
     * @param String  key 
     * @param int start 开始区间,从0开始(包含) 
     * @param int end 结束区间,-1为最后一个元素(包含) 
     * @return 删除的数量 
     * */  
    public long zremrangeByRank(String key, int start, int end)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.zremrangeByRank(key, start, end);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 删除给定权重区间的元素 
     * @param String key 
     * @param double min 下限权重(包含) 
     * @param double max 上限权重(包含) 
     * @return 删除的数量 
     * */  
    public long zremrangeByScore(String key, double min, double max)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.zremrangeByScore(key, min, max);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 获取给定区间的元素,原始按照权重由高到低排序 
     * @param String  key 
     * @param int start 
     * @param int end 
     * @return Set<String> 
     * */  
    public Set<String> zrevrange(String key, int start, int end) 
    {  
        Jedis jedis = getJedis();   
        Set<String> set = jedis.zrevrange(key, start, end);  
        closeResource(jedis); 
        return set;  
    }  

    /** 
     * 获取给定值在集合中的权重 
     * @param String  key 
     * @param memeber 
     * @return double 权重 
     * */  
    public double zscore(String key, String memebr)
    {  
        Jedis jedis = getJedis();   
        Double score = jedis.zscore(key, memebr);  
        closeResource(jedis); 
        if (score != null)  
            return score;  
        return 0;  
    }   
  
    //**********************Hash*************************//  

    /** 
     * 从hash中删除指定的存储 
     * @param String key 
     * @param String  fieid 存储的名字 
     * @return 状态码,1成功,0失败 
     * */  
    public long hdel(String key, String fieid)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.hdel(key, fieid);  
        closeResource(jedis);  
        return s;  
    }  

    public long hdel(String key)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.del(key);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 测试hash中指定的存储是否存在 
     * @param String key 
     * @param String  fieid 存储的名字 
     * @return 1存在,0不存在 
     * */  
    public boolean hexists(String key, String fieid) 
    {  
        Jedis jedis = getJedis();   
        boolean s = jedis.hexists(key, fieid);  
        closeResource(jedis); 
        return s;  
    }  

    /** 
     * 返回hash中指定存储位置的值 
     *  
     * @param String key 
     * @param String fieid 存储的名字 
     * @return 存储对应的值 
     * */  
    public String hget(String key, String fieid) 
    {  
        Jedis jedis = getJedis();   
        String s = jedis.hget(key, fieid);  
        closeResource(jedis); 
        return s;  
    }  

    public byte[] hget(byte[] key, byte[] fieid)
    {  
        Jedis jedis = getJedis();   
        byte[] s = jedis.hget(key, fieid);  
        closeResource(jedis); 
        return s;  
    }  

    /** 
     * 以Map的形式返回hash中的存储和值 
     * @param String    key 
     * @return Map<Strinig,String> 
     * */  
    public Map<String, String> hgetAll(String key) 
    {  
        Jedis jedis = getJedis();   
        Map<String, String> map = jedis.hgetAll(key);  
        closeResource(jedis); 
        return map;  
    }  

    /** 
     * 添加一个对应关系 
     * @param String  key 
     * @param String fieid 
     * @param String value 
     * @return 状态码 1成功,0失败,fieid已存在将更新,也返回0 
     * **/  
    public long hset(String key, String fieid, String value) 
    {  
        Jedis jedis = getJedis();  
        long s = jedis.hset(key, fieid, value);  
        closeResource(jedis);  
        return s;  
    }  

    public long hset(String key, String fieid, byte[] value) 
    {  
        Jedis jedis = getJedis();  
        long s = jedis.hset(key.getBytes(), fieid.getBytes(), value);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 添加对应关系,只有在fieid不存在时才执行 
     * @param String key 
     * @param String fieid 
     * @param String value 
     * @return 状态码 1成功,0失败fieid已存 
     * **/  
    public long hsetnx(String key, String fieid, String value)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.hsetnx(key, fieid, value);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 获取hash中value的集合 
     *  
     * @param String 
     *            key 
     * @return List<String> 
     * */  
    public List<String> hvals(String key)
    {  
        Jedis jedis = getJedis();   
        List<String> list = jedis.hvals(key);  
        closeResource(jedis); 
        return list;  
    }  

    /** 
     * 在指定的存储位置加上指定的数字,存储位置的值必须可转为数字类型 
     * @param String  key 
     * @param String  fieid 存储位置 
     * @param String long value 要增加的值,可以是负数 
     * @return 增加指定数字后,存储位置的值 
     * */  
    public long hincrby(String key, String fieid, long value)
    {  
        Jedis jedis = getJedis();  
        long s = jedis.hincrBy(key, fieid, value);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 返回指定hash中的所有存储名字,类似Map中的keySet方法 
     * @param String key 
     * @return Set<String> 存储名称的集合 
     * */  
    public Set<String> hkeys(String key)
    {  
        Jedis jedis = getJedis();   
        Set<String> set = jedis.hkeys(key);  
        closeResource(jedis); 
        return set;  
    }  

    /** 
     * 获取hash中存储的个数,类似Map中size方法 
     * @param String  key 
     * @return long 存储的个数 
     * */  
    public long hlen(String key)
    {  
        Jedis jedis = getJedis();    
        long len = jedis.hlen(key);  
        closeResource(jedis); 
        return len;  
    }  

    /** 
     * 根据多个key,获取对应的value,返回List,如果指定的key不存在,List对应位置为null 
     * @param String  key 
     * @param String ... fieids 存储位置 
     * @return List<String> 
     * */  
    public List<String> hmget(String key, String... fieids)
    {  
        //ShardedJedis jedis = getShardedJedis();  
        Jedis jedis = getJedis();   
        List<String> list = jedis.hmget(key, fieids);  
        closeResource(jedis); 
        return list;  
    }  

    public List<byte[]> hmget(byte[] key, byte[]... fieids) 
    {  
        //ShardedJedis jedis = getShardedJedis();  
        Jedis jedis = getJedis();    
        List<byte[]> list = jedis.hmget(key, fieids);  
        closeResource(jedis); 
        return list;  
    }  

    /** 
     * 添加对应关系,如果对应关系已存在,则覆盖 
     * @param Strin   key 
     * @param Map <String,String> 对应关系 
     * @return 状态,成功返回OK 
     * */  
    public String hmset(String key, Map<String, String> map)
    {  
        Jedis jedis = getJedis();  
        String s = jedis.hmset(key, map);  
        closeResource(jedis);  
        return s;  
    }  

    /** 
     * 添加对应关系,如果对应关系已存在,则覆盖 
     * @param Strin key 
     * @param Map <String,String> 对应关系 
     * @return 状态,成功返回OK 
     * */  
    public String hmset(byte[] key, Map<byte[], byte[]> map) {  
        Jedis jedis = getJedis();  
        String s = jedis.hmset(key, map);  
        closeResource(jedis);  
        return s;  
    }  
  
    //**********************Strings*********************//   
   
    /** 
     * 根据key获取记录 
     * @param String  key 
     * @return 值 
     * */  
    public String get(String key)
    {  
        Jedis jedis = getJedis();    
        String value = jedis.get(key);  
        closeResource(jedis); 
        return value;  
    }  

    /** 
     * 根据key获取记录 
     * @param byte[] key 
     * @return 值 
     * */  
    public byte[] get(byte[] key) 
    {  
        Jedis jedis = getJedis();    
        byte[] value = jedis.get(key);  
        closeResource(jedis); 
        return value;  
    }  

    /** 
     * 添加有过期时间的记录 
     *  
     * @param String  key 
     * @param int seconds 过期时间,以秒为单位 
     * @param String value 
     * @return String 操作状态 
     * */  
    public String setEx(String key, int seconds, String value) 
    {  
        Jedis jedis = getJedis();  
        String str = jedis.setex(key, seconds, value);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 添加有过期时间的记录 
     *  
     * @param String key 
     * @param int seconds 过期时间,以秒为单位 
     * @param String  value 
     * @return String 操作状态 
     * */  
    public String setEx(byte[] key, int seconds, byte[] value)
    {  
        Jedis jedis = getJedis();  
        String str = jedis.setex(key, seconds, value);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 添加一条记录,仅当给定的key不存在时才插入 
     * @param String key 
     * @param String value 
     * @return long 状态码,1插入成功且key不存在,0未插入,key存在 
     * */  
    public long setnx(String key, String value)
    {  
        Jedis jedis = getJedis();  
        long str = jedis.setnx(key, value);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 添加记录,如果记录已存在将覆盖原有的value 
     * @param String key 
     * @param String value 
     * @return 状态码 
     * */  
    public String set(String key, String value)
    {  
        return set(SafeEncoder.encode(key), SafeEncoder.encode(value));  
    }  

    /** 
     * 添加记录,如果记录已存在将覆盖原有的value 
     * @param String  key 
     * @param String value 
     * @return 状态码 
     * */  
    public String set(String key, byte[] value)
    {  
        return set(SafeEncoder.encode(key), value);  
    }  

    /** 
     * 添加记录,如果记录已存在将覆盖原有的value 
     * @param byte[] key 
     * @param byte[] value 
     * @return 状态码 
     * */  
    public String set(byte[] key, byte[] value)
    {  
        Jedis jedis = getJedis();  
        String status = jedis.set(key, value);  
        closeResource(jedis);  
        return status;  
    }  

    /** 
     * 从指定位置开始插入数据,插入的数据会覆盖指定位置以后的数据
     * 例:String str1="123456789";<br/> 
     * 对str1操作后setRange(key,4,0000),str1="123400009"; 
     * @param String  key 
     * @param long offset 
     * @param String  value 
     * @return long value的长度 
     * */  
    public long setRange(String key, long offset, String value) 
    {  
        Jedis jedis = getJedis();  
        long len = jedis.setrange(key, offset, value);  
        closeResource(jedis);  
        return len;  
    }  

    /** 
     * 在指定的key中追加value 
     * @param String  key 
     * @param String value 
     * @return long 追加后value的长度 
     * **/  
    public long append(String key, String value) 
    {  
        Jedis jedis = getJedis();  
        long len = jedis.append(key, value);  
        closeResource(jedis);  
        return len;  
    }  

    /** 
     * 将key对应的value减去指定的值,只有value可以转为数字时该方法才可用 
     * @param String key 
     * @param long number 要减去的值 
     * @return long 减指定值后的值 
     * */  
    public long decrBy(String key, long number)
    {  
        Jedis jedis = getJedis();  
        long len = jedis.decrBy(key, number);  
        closeResource(jedis);  
        return len;  
    }  

    /** 
     * 可以作为获取唯一id的方法
     * 将key对应的value加上指定的值,只有value可以转为数字时该方法才可用 
     * @param String  key 
     * @param long number 要减去的值 
     * @return long 相加后的值 
     * */  
    public long incrBy(String key, long number) 
    {  
        Jedis jedis = getJedis();  
        long len = jedis.incrBy(key, number);  
        closeResource(jedis);  
        return len;  
    }  

    /** 
     * 对指定key对应的value进行截取  
     * @param String   key 
     * @param long startOffset 开始位置(包含) 
     * @param long endOffset 结束位置(包含) 
     * @return String 截取的值 
     * */  
    public String getrange(String key, long startOffset, long endOffset)
    {  
        Jedis jedis = getJedis();    
        String value = jedis.getrange(key, startOffset, endOffset);  
        closeResource(jedis);  
        return value;  
    }  

    /** 
     * 获取并设置指定key对应的value
     * 如果key存在返回之前的value,否则返回null 
     * @param String  key 
     * @param String value 
     * @return String 原始value或null 
     * */  
    public String getSet(String key, String value)
    {  
        Jedis jedis = getJedis();  
        String str = jedis.getSet(key, value);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 批量获取记录,如果指定的key不存在返回List的对应位置将是null 
     * @param String keys 
     * @return List<String> 值得集合 
     * */  
    public List<String> mget(String... keys)
    {  
        Jedis jedis = getJedis();  
        List<String> str = jedis.mget(keys);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 批量存储记录 
     * @param String keysvalues 例:keysvalues="key1","value1","key2","value2"; 
     * @return String 状态码  
     * */  
    public String mset(String... keysvalues) 
    {  
        Jedis jedis = getJedis();  
        String str = jedis.mset(keysvalues);  
        closeResource(jedis);  
        return str;  
    }  

    /** 
     * 获取key对应的值的长度 
     * @param String key 
     * @return value值得长度 
     * */  
    public long strlen(String key) 
    {  
        Jedis jedis = getJedis();  
        long len = jedis.strlen(key);  
        closeResource(jedis);  
        return len;  
    }  
  
    //***********************Lists******************//  

    /** 
     * List长度 
     * @param String key 
     * @return 长度 
     * */  
    public long llen(String key) 
    {  
        return llen(SafeEncoder.encode(key));  
    }  

    /** 
     * List长度 
     * @param byte[] key 
     * @return 长度 
     * */  
    public long llen(byte[] key) 
    {  
        Jedis jedis = getJedis();    
        long count = jedis.llen(key);  
        closeResource(jedis); 
        return count;  
    }  

    /** 
     * 覆盖操作,将覆盖List中指定位置的值 
     * @param byte[] key 
     * @param int index 位置 
     * @param byte[] value 值 
     * @return 状态码 
     * */  
    public String lset(byte[] key, int index, byte[] value)
    {  
        Jedis jedis = getJedis();  
        String status = jedis.lset(key, index, value);  
        closeResource(jedis);  
        return status;  
    }  

    /** 
     * 覆盖操作,将覆盖List中指定位置的值 
     * @param key 
     * @param int index 位置 
     * @param String  value 值 
     * @return 状态码 
     * */  
    public String lset(String key, int index, String value)
    {  
        return lset(SafeEncoder.encode(key), index,  
                SafeEncoder.encode(value));  
    }  

    /** 
     * 在value的相对位置插入记录 
     * @param key 
     * @param LIST_POSITION   前面插入或后面插入 
     * @param String pivot 相对位置的内容 
     * @param String value 插入的内容 
     * @return 记录总数 
     * */  
    public long linsert(String key, LIST_POSITION where, String pivot,  
            String value) 
    {  
        return linsert(SafeEncoder.encode(key), where,  
                SafeEncoder.encode(pivot), SafeEncoder.encode(value));  
    }  

    /** 
     * 在指定位置插入记录 
     * @param String key 
     * @param LIST_POSITION 前面插入或后面插入 
     * @param byte[] pivot 相对位置的内容 
     * @param byte[] value 插入的内容 
     * @return 记录总数 
     * */  
    public long linsert(byte[] key, LIST_POSITION where, byte[] pivot,  
            byte[] value) 
    {  
        Jedis jedis = getJedis();  
        long count = jedis.linsert(key, where, pivot, value);  
        closeResource(jedis);  
        return count;  
    }  

    /** 
     * 获取List中指定位置的值 
     * @param String  key 
     * @param int index 位置  
     * @return 值 
     * **/  
    public String lindex(String key, int index) 
    {  
        return SafeEncoder.encode(lindex(SafeEncoder.encode(key), index));  
    }  

    /** 
     * 获取List中指定位置的值  
     * @param byte[] key 
     * @param int index 位置 
     * @return 值 
     * **/  
    public byte[] lindex(byte[] key, int index) 
    {   
        Jedis jedis = getJedis();    
        byte[] value = jedis.lindex(key, index);  
        closeResource(jedis); 
        return value;  
    }  

    /** 
     * 将List中的第一条记录移出List 
     * @param String key 
     * @return 移出的记录  
     * */  
    public String lpop(String key)
    {  
        return SafeEncoder.encode(lpop(SafeEncoder.encode(key)));  
    }  

    /** 
     * 将List中的第一条记录移出List 
     * @param byte[] key 
     * @return 移出的记录 
     * */  
    public byte[] lpop(byte[] key)
    {  
        Jedis jedis = getJedis();  
        byte[] value = jedis.lpop(key);  
        closeResource(jedis);  
        return value;  
    }  

    /** 
     * 将List中最后第一条记录移出List 
     *  
     * @param byte[] key 
     * @return 移出的记录 
     * */  
    public String rpop(String key)
    {  
        Jedis jedis = getJedis();  
        String value = jedis.rpop(key);  
        closeResource(jedis);  
        return value;  
    }  

    /** 
     * 向List尾部追加记录 
     * @param String key 
     * @param String value 
     * @return 记录总数 
     * */  
    public long lpush(String key, String value) 
    {  
        return lpush(SafeEncoder.encode(key), SafeEncoder.encode(value));  
    }  

    /** 
     * 向List头部追加记录 
     * @param String  key 
     * @param String  value 
     * @return 记录总数 
     * */  
    public long rpush(String key, String value)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.rpush(key, value);  
        closeResource(jedis);  
        return count;  
    }  

    /** 
     * 向List头部追加记录 
     * @param String key 
     * @param String value 
     * @return 记录总数 
     * */  
    public long rpush(byte[] key, byte[] value) 
    {  
        Jedis jedis = getJedis();  
        long count = jedis.rpush(key, value);  
        closeResource(jedis);  
        return count;  
    }  

    /** 
     * 向List中追加记录 
     * @param byte[] key 
     * @param byte[] value 
     * @return 记录总数 
     * */  
    public long lpush(byte[] key, byte[] value)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.lpush(key, value);  
        closeResource(jedis);  
        return count;  
    }  

    /** 
     * 获取指定范围的记录,可以做为分页使用 
     * @param String key 
     * @param long start 
     * @param long end 
     * @return List 
     * */  
    public List<String> lrange(String key, long start, long end) 
    {  
        Jedis jedis = getJedis();     
        List<String> list = jedis.lrange(key, start, end);  
        closeResource(jedis); 
        return list;  
    }  

    /** 
     * 获取指定范围的记录,可以做为分页使用 
     * @param byte[] key 
     * @param int start 
     * @param int end 如果为负数,则尾部开始计算 
     * @return List 
     * */  
    public List<byte[]> lrange(byte[] key, int start, int end)
    {  
        //ShardedJedis jedis = getShardedJedis();  
        Jedis jedis = getJedis();     
        List<byte[]> list = jedis.lrange(key, start, end);  
        closeResource(jedis); 
        return list;  
    }  

    /** 
     * 删除List中c条记录,被删除的记录值为value 
     * @param byte[] key 
     * @param int c 要删除的数量,如果为负数则从List的尾部检查并删除符合的记录 
     * @param byte[] value 要匹配的值 
     * @return 删除后的List中的记录数 
     * */  
    public long lrem(byte[] key, int c, byte[] value)
    {  
        Jedis jedis = getJedis();  
        long count = jedis.lrem(key, c, value);  
        closeResource(jedis);  
        return count;  
    }  

    /** 
     * 删除List中c条记录,被删除的记录值为value 
     * @param String key 
     * @param int c 要删除的数量,如果为负数则从List的尾部检查并删除符合的记录 
     * @param String value 要匹配的值 
     * @return 删除后的List中的记录数 
     * */  
    public long lrem(String key, int c, String value)
    {  
        return lrem(SafeEncoder.encode(key), c, SafeEncoder.encode(value));  
    }  

    /** 
     * 算是删除吧,只保留start与end之间的记录 
     * @param byte[] key 
     * @param int start 记录的开始位置(0表示第一条记录) 
     * @param int end 记录的结束位置(如果为-1则表示最后一个,-2,-3以此类推) 
     * @return 执行状态码 
     * */  
    public String ltrim(byte[] key, int start, int end)
    {  
        Jedis jedis = getJedis();  
        String str = jedis.ltrim(key, start, end);  
        closeResource(jedis);  
        return str;  
    }  

    /**  
     * 算是删除吧,只保留start与end之间的记录 
     * @param String key  
     * @param int start 记录的开始位置(0表示第一条记录) 
     * @param int end 记录的结束位置(如果为-1则表示最后一个,-2,-3以此类推) 
     * @return 执行状态码 
     * */  
    public String ltrim(String key, int start, int end)
    {  
        return ltrim(SafeEncoder.encode(key), start, end);  
    }  
    
}

2、PropertiesUtils.java如下:

package com.jwang.ssmxml.common.util;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Properties;

import org.apache.log4j.Logger;

/**
 * @author jwang
 * properties文件读写工具类
 *
 */
public abstract class PropertiesUtils 
{
	private static final Logger LOG = Logger.getLogger(PropertiesUtils.class);
	
	public static Properties getProperties(String path)
	{
		Properties prop = new Properties();
		
		loadProp(prop, path);
		
		return prop;
	}
	
	private static void loadProp(Properties p, String conf)
	{
		InputStream is = getInputStream(conf);
		
		if(null != is)
		{
			try 
			{
				p.load(is);
			} 
			catch (IOException e)
			{
				LOG.info("file not found!");
			}
			finally
			{
				if(is != null)
				{
					try 
					{
						is.close();
					} 
					catch (IOException e)
					{
						LOG.info("stream close fail!");
					}
				}
			}
		}
	}
	
	//获取输入流
	private static InputStream getInputStream(String conf)
	{
		ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
		
		InputStream is = null;
		
		if(null != classLoader)
		{
			is = classLoader.getResourceAsStream(conf);
		}
		return is;
	}
	
	//获取输出流
	private static OutputStream getOutPutStream(String conf)
	{
		ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
		
		OutputStream out = null;
		
		if(null != classLoader)
		{
			String filePath = classLoader.getResource(conf).getFile();
			try 
			{
				out = new FileOutputStream(filePath);
			} 
			catch (FileNotFoundException e) 
			{
				LOG.info("file not found!!!");
			}
		}
		return out;
	}
	
	//读取key=value
	public static String getValue(Properties p, String key)
	{
		String value = p.getProperty(key);
		
		return value == null?"":value;
	} 
	
	//设置key=value
	public static void setValue(String conf, String key, String value)
	{
		Properties p = getProperties(conf);
		
		OutputStream out = getOutPutStream(conf);
		
		p.setProperty(key, value);
		
		try 
		{
			p.store(out, "set:"+key+"="+value);
		} 
		catch (IOException e)
		{
			LOG.info("set properties fail!!!");
		}
		finally
		{
			if(out != null)
			{
				try 
				{
					out.close();
				} 
				catch (IOException e)
				{
					LOG.info("stream close fail!");
				}
			}
		}
	}
	
}

3、SerializeUtils.java如下:

package com.jwang.sshxml.common.util;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

import org.apache.log4j.Logger;

/**
 * 序列化:把对象转换为字节序列的过程称为对象的序列化
 * 反序列化:把字节序列恢复为对象的过程称为对象的反序列化
 * 
 * 序列化和反序列化的工具类
 * @author jwang
 *
 */
public class SerializeUtils
{
    private static final Logger LOGGER = Logger.getLogger(SerializeUtils.class);
    /** 
     * 序列化 
     *  
     * @param object 
     * @return 
     */  
    public static byte[] serialize(Object object) 
    {  
        ObjectOutputStream objectOutputStream = null;  
        ByteArrayOutputStream byteArrayOutputStream = null;  
        try
        {  
            // 序列化  
            byteArrayOutputStream = new ByteArrayOutputStream();  
            objectOutputStream = new ObjectOutputStream(byteArrayOutputStream);  
            objectOutputStream.writeObject(object);  
            byte[] bytes = byteArrayOutputStream.toByteArray();  
            return bytes;  
        }
        catch (Exception e)
        {  
            LOGGER.error("对象序列化失败!!!");
            e.printStackTrace();
        }  
        return null;  
    }  
  
    /** 
     * 反序列化 
     *  
     * @param bytes 
     * @return 
     */  
    public static Object unserialize(byte[] bytes) 
    {  
        ByteArrayInputStream byteArrayInputStream = null;  
        try 
        {  
            // 反序列化  
            byteArrayInputStream = new ByteArrayInputStream(bytes);  
            ObjectInputStream objectInputStream = new ObjectInputStream(byteArrayInputStream);  
            return objectInputStream.readObject();  
        } 
        catch (Exception e)
        {  
            LOGGER.error("对象反序列化失败!!!");
            e.printStackTrace();
        }  
        return null;  
    }  
    
}

参考文章:https://blog.csdn.net/liuxiao723846/article/details/50401406

猜你喜欢

转载自blog.csdn.net/m0_38045882/article/details/80431426
今日推荐