Java 中常用缓存Cache机制的实现

所谓缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例。这样做可以减少系统开销,提高系统效率。

所谓缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例。这样做可以减少系统开销,提高系统效率。

缓存主要可分为二大类:

一、通过文件缓存,顾名思义文件缓存是指把数据存储在磁盘上,不管你是以XML格式,序列化文件DAT格式还是其它文件格式;

二、内存缓存,也就是实现一个类中静态Map,对这个Map进行常规的增删查.

代码如下:

package lhm.hcy.guge.frameset.cache; 

import java.util.*; 

 //Description: 管理缓存 

 //可扩展的功能:当chche到内存溢出时必须清除掉最早期的一些缓存对象,这就要求对每个缓存对象保存创建时间 

public class CacheManager {
    private static HashMap cacheMap = new HashMap(); 

    //单实例构造方法
    private CacheManager() {
        super();
    }
    //获取布尔值的缓存
    public static boolean getSimpleFlag(String key){
        try{
            return (Boolean) cacheMap.get(key);
        }catch(NullPointerException e){
            return false;
        }
    }
    public static long getServerStartdt(String key){
        try {
            return (Long)cacheMap.get(key);
        } catch (Exception ex) {
            return 0;
        }
    }
    //设置布尔值的缓存
    public synchronized static boolean setSimpleFlag(String key,boolean flag){
        if (flag && getSimpleFlag(key)) {//假如为真不允许被覆盖
            return false;
        }else{
            cacheMap.put(key, flag);
            return true;
        }
    }
    public synchronized static boolean setSimpleFlag(String key,long serverbegrundt){
        if (cacheMap.get(key) == null) {
            cacheMap.put(key,serverbegrundt);
            return true;
        }else{
            return false;
        }
    } 

    //得到缓存。同步静态方法
    private synchronized static Cache getCache(String key) {
        return (Cache) cacheMap.get(key);
    } 

    //判断是否存在一个缓存
    private synchronized static boolean hasCache(String key) {
        return cacheMap.containsKey(key);
    } 

    //清除所有缓存
    public synchronized static void clearAll() {
        cacheMap.clear();
    } 

    //清除某一类特定缓存,通过遍历HASHMAP下的所有对象,来判断它的KEY与传入的TYPE是否匹配
    public synchronized static void clearAll(String type) {
        Iterator i = cacheMap.entrySet().iterator();
        String key;
        ArrayList arr = new ArrayList();
        try {
            while (i.hasNext()) {
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
                key = (String) entry.getKey();
                if (key.startsWith(type)) { //如果匹配则删除掉
                    arr.add(key);
                }
            }
            for (int k = 0; k < arr.size(); k++) {
                clearOnly(arr.get(k));
            }
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    } 

    //清除指定的缓存
    public synchronized static void clearOnly(String key) {
        cacheMap.remove(key);
    } 

    //载入缓存
    public synchronized static void putCache(String key, Cache obj) {
        cacheMap.put(key, obj);
    } 

    //获取缓存信息
    public static Cache getCacheInfo(String key) { 

        if (hasCache(key)) {
            Cache cache = getCache(key);
            if (cacheExpired(cache)) { //调用判断是否终止方法
                cache.setExpired(true);
            }
            return cache;
        }else
            return null;
    } 

    //载入缓存信息
    public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) {
        Cache cache = new Cache();
        cache.setKey(key);
        cache.setTimeOut(dt + System.currentTimeMillis()); //设置多久后更新缓存
        cache.setValue(obj);
        cache.setExpired(expired); //缓存默认载入时,终止状态为FALSE
        cacheMap.put(key, cache);
    }
    //重写载入缓存信息方法
    public static void putCacheInfo(String key,Cache obj,long dt){
        Cache cache = new Cache();
        cache.setKey(key);
        cache.setTimeOut(dt+System.currentTimeMillis());
        cache.setValue(obj);
        cache.setExpired(false);
        cacheMap.put(key,cache);
    } 

    //判断缓存是否终止
    public static boolean cacheExpired(Cache cache) {
        if (null == cache) { //传入的缓存不存在
            return false;
        }
        long nowDt = System.currentTimeMillis(); //系统当前的毫秒数
        long cacheDt = cache.getTimeOut(); //缓存内的过期毫秒数
        if (cacheDt <= 0||cacheDt>nowDt) { //过期时间小于等于零时,或者过期时间大于当前时间时,则为FALSE
            return false;
        } else { //大于过期时间 即过期
            return true;
        }
    } 

    //获取缓存中的大小
    public static int getCacheSize() {
        return cacheMap.size();
    } 

    //获取指定的类型的大小
    public static int getCacheSize(String type) {
        int k = 0;
        Iterator i = cacheMap.entrySet().iterator();
        String key;
        try {
            while (i.hasNext()) {
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
                key = (String) entry.getKey();
                if (key.indexOf(type) != -1) { //如果匹配则删除掉
                    k++;
                }
            }
        } catch (Exception ex) {
            ex.printStackTrace();
        } 

        return k;
    } 

    //获取缓存对象中的所有键值名称
    public static ArrayList getCacheAllkey() {
        ArrayList a = new ArrayList();
        try {
            Iterator i = cacheMap.entrySet().iterator();
            while (i.hasNext()) {
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
                a.add((String) entry.getKey());
            }
        } catch (Exception ex) {} finally {
            return a;
        }
    } 

    //获取缓存对象中指定类型 的键值名称
    public static ArrayList getCacheListkey(String type) {
        ArrayList a = new ArrayList();
        String key;
        try {
            Iterator i = cacheMap.entrySet().iterator();
            while (i.hasNext()) {
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
                key = (String) entry.getKey();
                if (key.indexOf(type) != -1) {
                    a.add(key);
                }
            }
        } catch (Exception ex) {} finally {
            return a;
        }
    } 

} 

package lhm.hcy.guge.frameset.cache; 

public class Cache {
        private String key;//缓存ID
        private Object value;//缓存数据
        private long timeOut;//更新时间
        private boolean expired; //是否终止
        public Cache() {
                super();
        } 

        public Cache(String key, Object value, long timeOut, boolean expired) {
                this.key = key;
                this.value = value;
                this.timeOut = timeOut;
                this.expired = expired;
        } 

        public String getKey() {
                return key;
        } 

        public long getTimeOut() {
                return timeOut;
        } 

        public Object getValue() {
                return value;
        } 

        public void setKey(String string) {
                key = string;
        } 

        public void setTimeOut(long l) {
                timeOut = l;
        } 

        public void setValue(Object object) {
                value = object;
        } 

        public boolean isExpired() {
                return expired;
        } 

        public void setExpired(boolean b) {
                expired = b;
        }
} 

//测试类,
class Test {
    public static void main(String[] args) {
        System.out.println(CacheManager.getSimpleFlag("alksd"));
//        CacheManager.putCache("abc", new Cache());
//        CacheManager.putCache("def", new Cache());
//        CacheManager.putCache("ccc", new Cache());
//        CacheManager.clearOnly("");
//        Cache c = new Cache();
//        for (int i = 0; i < 10; i++) {
//            CacheManager.putCache("" + i, c);
//        }
//        CacheManager.putCache("aaaaaaaa", c);
//        CacheManager.putCache("abchcy;alskd", c);
//        CacheManager.putCache("cccccccc", c);
//        CacheManager.putCache("abcoqiwhcy", c);
//        System.out.println("删除前的大小:"+CacheManager.getCacheSize());
//        CacheManager.getCacheAllkey();
//        CacheManager.clearAll("aaaa");
//        System.out.println("删除后的大小:"+CacheManager.getCacheSize());
//        CacheManager.getCacheAllkey(); 

    }
}

spring中的redis service实现

package com.eshore.ismp.cache.redis;

import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataAccessException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;

@Service
public class RedisService {

	private static String redisCode = "utf-8";

	@Autowired
	private RedisTemplate<String, String> redisTemplate;

	/**
	 * 从指定的列表右边出队,添加到目的列表中
	 *
	 * @param srckey
	 *            源列表
	 * @param dstkey
	 *             目的列表
	 * @return
	 */
	public String rpoppush(final String srckey, final String dstkey) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				try {
					return new String (connection.rPopLPush(srckey.getBytes(), dstkey.getBytes()), redisCode);
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}
				return "";
			}
		});
	}
	/**
	 * 获取指定列表的范围数据
	 *
	 * @param key
	 *             列表名
	 * @param start
	 *             开始位置
	 * @param end
	 *             结束位置
	 * @return
	 */
	public List<String> lrange(final String key, final int start, final int end) {
		return redisTemplate.execute(new RedisCallback<List<String>>() {
			List<String> result = new ArrayList<String>();
			public List<String> doInRedis(RedisConnection connection)
					throws DataAccessException {
				List<byte[]> bytelist= connection.lRange(key.getBytes(), start, end);
				for (byte[] b : bytelist) {
					try {
						result.add(new String(b, redisCode));
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return result;
			}
		});
	}
	/**
	 * 从队列的左边取出一条数据
	 *
	 * @param key
	 *             列表名
	 * @return
	 */
	public String lpop(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] result = connection.lPop(key.getBytes());
				if (result != null) {
					try {
						return new String (result , redisCode);
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return "";
			}
		});
	}

	/**
	 * 从队列的左边取出一条数据
	 *
	 * @param key
	 *             列表名
	 * @return
	 */
	public List<?> lpop(final String key,final int size) {
		List<Object> list =  redisTemplate.executePipelined(new RedisCallback<List<Object>>() {
			public List<Object> doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] keyBytes = key.getBytes();
				for(int i =0 ; i< size; i++){
					connection.lPop(keyBytes);
				}
				return null;
			}
		});
		list.removeAll(Collections.singleton(null));
		return list;
	}

	/**
	 * 从列表右边添加数据
	 *
	 * @param key
	 *            列表名
	 * @param values
	 *            数据
	 * @return
	 */
	public long rpush(final String key, final String... values) {
        return redisTemplate.execute(new RedisCallback<Long>() {
            public Long doInRedis(RedisConnection connection)
                    throws DataAccessException {
                long result = 0;
                for (String v : values) {
                	result = connection.rPush(key.getBytes(), v.getBytes());
                }
                return result;
            }
        });
	}

	/**
	 * 从列表右边添加数据
	 *
	 * @param key
	 *            列表名
	 * @param values
	 *            数据
	 * @return
	 */
	public long rpush(final String key, final Collection<String> values) {
		return redisTemplate.opsForList().rightPushAll(key, values);
	}

	public int hmset(final String key, final Map<String,String> values) {
		try{
		 redisTemplate.opsForHash().putAll(key, values);
		}catch(Exception e){
			e.printStackTrace();
			return -1;
		}
		return 0 ;
	}
	public String hget(final String key, final String field){
		Object obj =redisTemplate.opsForHash().get(key, field);
		return String.valueOf(obj);
	}

	public List<?> hkeys(final String key){
		return redisTemplate.execute(new RedisCallback<List<Object>>(){
			List<Object> list = new ArrayList<Object>();
			public List<Object> doInRedis(RedisConnection connection)
					throws DataAccessException {
				Set<byte[]> sets=connection.hKeys(key.getBytes());
				if(!sets.isEmpty()){
					for(byte[] b : sets){
						list.add(redisTemplate.getValueSerializer().deserialize(b).toString());
					}
					return list;
				}
				return null;
			}
		});
	}

	/**
	 * 删除hash表中field
	 */
	public void hdel(final String key,final String field){
		redisTemplate.opsForHash().delete(key, field);
	}
	/**
	 * 从列表右边添加数据,并且设置列表的存活时间
	 *
	 * @param key
	 *            列表名
	 * @param liveTime
	 *            存活时间(单位 秒)
	 * @param values
	 *            数据
	 * @return
	 */
	public long rpush(final String key, final int liveTime, final String... values) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0;
				for (String v : values) {
					connection.rPush(key.getBytes(), v.getBytes());
				}
				if (liveTime > 0) {
					connection.expire(key.getBytes(), liveTime);
				}
				return result;
			}
		});
	}
	/**
	 * 从队列的右边取出一条数据
	 *
	 * @param key
	 *            列表名
	 * @return
	 */
	public String rpop(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] result = connection.rPop(key.getBytes());
				if(result != null ){
					try {
						return new String (result, redisCode);
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return "";
			}
		});
	}
	/**
	 * 把一个值添加到对应列表中
	 *
	 * @param key
	 *            列表名
	 * @param index
	 *             添加的位置
	 * @param value
	 *             数据
	 * @return
	 */
	public String lset(final String key, final long index, final String value) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.lSet(key.getBytes(), index, value.getBytes());
				return "success";
			}
		});
	}
	/**
	 * 把所有数据添加到一个列表中
	 *
	 * @param key
	 *            列表名
	 * @param values
	 *             数据
	 * @return
	 */
	public long lpush(String key, String... values) {
		return this.lpush(key, 0, values);
	}
	/**
	 * 把所有数据添加到一个列表中,并且设置列表的存活时间
	 *
	 * @param key
	 *            列表名
	 * @param values
	 *            数据
	 * @param liveTime
	 *            存活时间--单位(秒)
	 * @return
	 */
	public long lpush(final String key,final  int liveTime, final String... values) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0;
				for (String v : values){
					result = connection.lPush(key.getBytes(), v.getBytes());
				}
				if (liveTime > 0) {
					connection.expire(key.getBytes(), liveTime);
				}
				return result;
			}
		});
	}
	/**
	 * 返回列表的长度
	 *
	 * @param key
	 * @return
	 */
	public long llen(final String key) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.lLen(key.getBytes());
			}
		});
	}
	/**
	 * 删除列表中对应值的元素
	 *
	 * @param key
	 *            列表名
	 * @param count
	 *            删除多少个相同的元素
	 * @param value
	 *            数据
	 * @return
	 */
	public long lrem(final String key, final long count, final String value) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.lRem(key.getBytes(), count, value.getBytes());
			}
		});
	}
	/**
	 * 通过keys批量删除
	 *
	 * @param key
	 */
	public long del(final String... keys) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0;
				for (String k : keys) {
					result = connection.del(k.getBytes());
				}
				return result;
			}
		});
	}

	/**
	 *
	 * //DESC 删除单个key
	 * @time: 2016年5月27日 上午9:00:36
	 * @param key
	 * @return
	 * @throws
	 */
	public long del(final String key){
		return redisTemplate.execute(new RedisCallback<Long>(){
			@Override
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.del(key.getBytes());
			}

		});
	}

	/**
	 * 添加key value 并且设置存活时间(byte)
	 *
	 * @param key
	 * @param value
	 * @param liveTime
	 */
	public void set(final byte[] key, final byte[] value, final long liveTime) {
		redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.set(key, value);
                if (liveTime > 0) {
                    connection.expire(key, liveTime);
                }
				return 1L;
			}
		});

	}
	/**
	 * 添加key value 并且设置存活时间
	 *
	 * @param key
	 * @param value
	 * @param liveTime
	 *            单位秒
	 */
	public void set(String key, String value, long liveTime) {
		this.set(key.getBytes(), value.getBytes(), liveTime);

	}
	/**
	 * 添加key value
	 *
	 * @param key
	 * @param value
	 */
	public void set(String key, String value) {
		this.set(key, value, 0L);
	}

	/**
	 * 添加key value
	 *
	 * @param key
	 * @param value
	 */
	public void setMulti(final Map<String,String> map) {
		setMulti(map,0L);
	}

	/**
	 * 添加key value
	 *
	 * @param key
	 * @param value
	 */
	public void setMulti(final Map<String,String> map,final long liveTime) {
		 redisTemplate.executePipelined(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				Set<Map.Entry<String, String >> set = map.entrySet();
				for (Entry<String, String> entry : set) {
					connection.set(entry.getKey().getBytes(), entry.getValue().getBytes());
					if (liveTime > 0) {
		                connection.expire(entry.getKey().getBytes(), liveTime);
		            }
				}
				return null;
			}
		});
	}
	/**
	 * 添加key value (字节)(序列化)
	 *
	 * @param key
	 * @param value
	 */
	public void set(byte[] key, byte[] value) {
		this.set(key, value, 0L);

	}
	/**
	 * 获取redis value (String)
	 *
	 * @param key
	 * @return
	 */
	public String get(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
			byte[] result = connection.get(key.getBytes());
			if (result != null) {
				try {
					return new String (result ,redisCode);
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}
			}
			return "";
			}
		});
	}
	/**
	 * 如果key不存在添加key value 并且设置存活时间(byte),当key已经存在时,就不做任何操作
	 *
	 * @param key
	 * @param value
	 * @param liveTime
	 */
	public long setnx(final byte[] key, final byte[] value, final long liveTime) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0l;
				boolean isSuccess = connection.setNX(key, value);
                if (isSuccess) {
                	if (liveTime > 0) {
                        connection.expire(key, liveTime);
                    }
					result = 1l;
				}
				return result;
			}
		});
	}
	/**
	 * 如果key不存在添加key value 并且设置存活时间,当key已经存在时,就不做任何操作
	 *
	 * @param key
	 * @param value
	 * @param liveTime
	 *            单位秒
	 */
	public long setnx(String key, String value, long liveTime) {
		return this.setnx(key.getBytes(), value.getBytes(), liveTime);

	}
	/**
	 * 如果key不存在添加key value,当key已经存在时,就不做任何操作
	 *
	 * @param key
	 * @param value
	 */
	public long setnx(String key, String value) {
		return this.setnx(key, value, 0L);
	}
	/**
	 * 如果key不存在添加key value (字节)(序列化),当key已经存在时,就不做任何操作
	 *
	 * @param key
	 * @param value
	 */
	public long setnx(byte[] key, byte[] value) {
		return this.setnx(key, value, 0L);

	}
	/**
	 * 通过正则匹配keys
	 *
	 * @param pattern
	 * @return
	 */
	public Set<String> keys(final String pattern) {
		return redisTemplate.execute(new RedisCallback<Set<String>>() {
			public Set<String> doInRedis(RedisConnection connection)
					throws DataAccessException {
			Set<String> result = new HashSet<String>();
			Set<byte[]>	data = connection.keys(pattern.getBytes());
			for(byte[] d : data){
				try {
					result.add(new String(d,redisCode));
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}
			}
			return result;
			}
		});
	}
	/**
	 * 检查key是否已经存在
	 *
	 * @param key
	 * @return
	 */
	public boolean exists(final String key) {
		return redisTemplate.execute(new RedisCallback<Boolean>() {
			public Boolean doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.exists(key.getBytes());
			}

		});
	}
	/**
	 * 清空redis 所有数据
	 *
	 * @return
	 */
	public String flushDB() {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.flushDb();
				return "success";
			}
		});
	}
	/**
	 * 查看redis里有多少数据
	 */
	public long dbSize() {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.dbSize();
			}
		});
	}
	/**
	 * 检查是否连接成功
	 *
	 * @return
	 */
	public String ping() {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.ping();
			}
		});
	}
	/**
	 * 设置key的生命周期
	 *
	 * @param key
	 * @param seconds
	 *            单位(秒)
	 * @return
	 */
	public boolean expire(final String key, final long seconds) {
		return redisTemplate.execute(new RedisCallback<Boolean>() {
			public Boolean doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.expire(key.getBytes(), seconds);
			}
		});
	}
	/**
	 * 自增长
	 *
	 * @param key
	 * @param length 增长步长
	 * @return
	 */
	public long incr (final String key){
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incr(key.getBytes());
			}

		});
	}
	/**
	 * 自增长
	 *
	 * @param key
	 * @param length 增长步长
	 * @return
	 */
	public long incrBy (final String key, final long len){
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incrBy(key.getBytes(), len);
			}
		});

	}
	/**
	 * 自增长
	 *
	 * @param key
	 * @param length 增长步长
	 * @return
	 */
	public double incrBy (final String key, final double len){
		return redisTemplate.execute(new RedisCallback<Double>() {
			public Double doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incrBy(key.getBytes(), len);
			}
		});
	}

    public long eval(final String luaCommand) {
        return redisTemplate.execute(new RedisCallback<Long>() {
            public Long doInRedis(RedisConnection connection) throws DataAccessException {
                return connection.eval(luaCommand.getBytes(), null,0);
            }
        });
    }

}

  

缓存应用:

package com.eshore.ismp.cache.processor;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.eshore.ismp.cache.redis.RedisService;
import com.eshore.ismp.common.entity.ResultInfo;

/**
 *
 * //DESC: 管理门户缓存接口
 * @author zzx
 * @date 2016年5月20日 上午11:50:25
 */
@Service
public class AdminWebProcessor {
	private static final Logger logger = Logger.getLogger(AdminWebProcessor.class);
	private static final String ADMINWEB_USER = "ADMINWEB_USER_";
	private static final Long LIVETIME = 60*30L;
	@Autowired
	RedisService redisService;

	public String put(JSONObject param){
		Long userId = param.getLong("user_id");
		String userInfo = param.getString("user_info");
		ResultInfo  rs = new ResultInfo();
		if(userId==null || StringUtils.isEmpty(userInfo)){
			logger.error("参数错误");
			rs.setResult_code(2501);
			rs.setResult_detail("参数错误");
			return JSON.toJSONString(rs);
		}
		String key = ADMINWEB_USER+userId;
		redisService.set(key , userInfo,LIVETIME);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		return JSON.toJSONString(rs);
	}

	public String get(JSONObject param){
		Long userId = param.getLong("user_id");
		String key = ADMINWEB_USER+userId;
		ResultInfo  rs = new ResultInfo();
		String user = redisService.get(key);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		rs.setResult_data(user);
		return JSON.toJSONString(rs);
	}

	public String delete(JSONObject param){
		Long userId = param.getLong("user_id");
		String key = ADMINWEB_USER+userId;
		ResultInfo  rs = new ResultInfo();
		long isDel = redisService.del(key);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		return JSON.toJSONString(rs);
	}

}

  

  

时间: 2024-10-17 22:53:25

Java 中常用缓存Cache机制的实现的相关文章

Java中常用缓存Cache机制的实现

缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例.这样做可以减少系统开销,提高系统效率. 缓存主要可分为二大类: 一.通过文件缓存,顾名思义文件缓存是指把数据存储在磁盘上,不管你是以XML格式,序列化文件DAT格式还是其它文件格式: 二.内存缓存,也就是实现一个类中静态Map,对这个Map进行常规的增删查. import java.util.*; //Description: 管理缓存 //可扩展的功能:当chche到内存溢出时必须清除掉最早

Java -- 常用缓存Cache机制的实现 -- 艺多不压身

常用缓存Cache机制的实现 缓存,就是将程序或系统经常要调用的对象存在内存中,以便其使用时可以快速调用,不必再去创建新的重复的实例. 这样做可以减少系统开销,提高系统效率. 缓存主要可分为二大类: 一.通过文件缓存,顾名思义文件缓存是指把数据存储在磁盘上,不管你是以XML格式,序列化文件DAT格式还是其它文件格式 二.内存缓存,也就是实现一个类中静态Map,对这个Map进行常规的增删查. 啦啦啦

HTTP请求中的缓存(cache)机制

http://www.chaorenmao.com/blog/?p=79 流程 当资源第一次被访问的时候,HTTP头部如下 (Request-Line)  GET /a.html HTTP/1.1Host    127.0.0.1User-Agent  Mozilla/5.0 (X11; U; Linux i686; zh-CN; rv:1.9.0.15) Gecko/2009102815 Ubuntu/9.04 (jaunty) Firefox/3.0.15Accept           

java中常用的锁机制

基础知识 基础知识之一:锁的类型 锁就那么几个,只是根据特性,分为不同的类型 锁的概念 在计算机科学中,锁(lock)或互斥(mutex)是一种同步机制,用于在有许多执行线程的环境中强制对资源的访问限制.锁旨在强制实施互斥排他.并发控制策略. 锁通常需要硬件支持才能有效实施.这种支持通常采取一个或多个原子指令的形式,如"test-and-set", "fetch-and-add" or "compare-and-swap"".这些指令允

java中常用的包、类、以及包中常用的类、方法、属性-----io包

由于最近有需要,所以下面是我整理的在开发中常用的包.类.以及包中常用的类.方法.属性:有需要的看看 java中常用的包.类.以及包中常用的类.方法.属性 常用的包 java.io.*; java.util.*; java.lang.*; java.math.*; java.sql.*; java.text.*; java.awt.*; javax.swing.*;   包名 接口 类 方法 属性 java.io.*; java.io.Serializable实现序列化 java.io.Buffe

java中常用的工具类(二)

下面继续分享java中常用的一些工具类,希望给大家带来帮助! 1.FtpUtil Java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71

java中常用的工具类

一.String工具类 package com.itjh.javaUtil; import java.util.ArrayList; import java.util.List; /** * * String工具类. <br> * * @author 宋立君 * @date 2014年06月24日 */ public class StringUtil { private static final int INDEX_NOT_FOUND = -1; private static final St

Java中常用的字符串API

Java中常用的字符串API 这些API都封装在了 import java.lang; (默认导入无需手工导入) 字符串.length() 返回字符串的长度 字符串1.equals(字符串2) 判断两个字符串内容是否一致(不能用==) 字符串1.equalsIgnoreCase(字符串2) 判断两个字符串内容是否一致(不区分大小写) 字符串.toLowerCase() 返回小写字符串 字符串.toUpperCase() 返回大写字符串 字符串1.concat(字符串2) 返回字符串1接上字符串2

java中常用的数据加密算法

以下为加密的工具类: import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.PublicKey; impo