redis缓存工具类,提供序列化接口
1、序列化工具类
package com.qicheshetuan.backend.util; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; public class SerializeUtil { //序列化
public static byte[] serialize(Object object) {
ObjectOutputStream oos = null;
ByteArrayOutputStream baos = null;
try { baos = new ByteArrayOutputStream();
oos = new ObjectOutputStream(baos);
oos.writeObject(object);
byte[] bytes = baos.toByteArray();
return bytes;
} catch (Exception e) {
}
return null;
}
//反序列化
public static Object unserialize(byte[] bytes) {
ByteArrayInputStream bais = null;
try { bais = new ByteArrayInputStream(bytes);
ObjectInputStream ois = new ObjectInputStream(bais);
return ois.readObject();
} catch (Exception e) {
}
return null;
}
}
SerializeUtil
2、redis工具类
@Component
public class RedisClientUtil {
@Autowired
private JedisPool jedisPool; /**
* 获取Jedis实例
*
* @return
*/
public Jedis getJedis() {
return jedisPool.getResource();
} /**
* 判断某个key是否存在
*
* @param key
* @return
*/
public boolean exist(String key) {
Jedis jedis = null;
try {
jedis = getJedis();
return jedis.exists(key);
} catch (Exception e) {
e.printStackTrace();
} finally {
// 返还到连接池
returnResource(jedis);
}
return false;
} /**
* 以key删除某个数据
*
* @param key
* @return
*/
public Long del(String key) {
Jedis jedis = null;
try {
jedis = getJedis();
return jedis.del(key);
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
// 返还到连接池
returnResource(jedis);
}
}
/**
* 将jedis返还到连接池
*
* @param jedis
*/
public void returnResource(Jedis jedis) {
if (jedis != null) {
jedisPool.returnResource(jedis);
}
} /**
* 存放数据
*
* @param key 存储的key
* @param value 需要存储的数据
* @param express key失效时间
* @return
*/
public <T> boolean setObject(String key, T value, int express) {
Jedis jedis = null;
try {
jedis = getJedis();
byte[] bytes = SerializeUtil.serialize(value);
jedis.set(key.getBytes(), bytes);
jedis.expire(key, express);
return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
//返还到连接池
returnResource(jedis);
}
return false;
} /**
* 删除key集合
*/
public <T> boolean delKeys(List<String> keys) {
Jedis jedis = null;
try {
jedis = getJedis();
for (String key : keys) {
jedis.del(key.getBytes());
}
return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
//返还到连接池
returnResource(jedis);
}
return false;
} /**
* 获取数据
*
* @param key 存储的key
* @return
*/
public <T> T getObject(String key) {
Object value = null;
Jedis jedis = null;
try {
jedis = getJedis();
byte[] bytes = jedis.get(key.getBytes());
value = SerializeUtil.unserialize(bytes);
} catch (Exception e) {
e.printStackTrace();
} finally {
// 返还到连接池
returnResource(jedis);
}
if (value != null) {
return (T) value;
}
return null;
} /**
* 将key的时间置为0,即清除缓存
*
* @param key 将key的时间置为0,即清除缓存
*/
public void expire(String key) {
Jedis jedis = null;
try {
jedis = getJedis();
jedis.expire(key, 0);
} catch (Exception e) {
e.printStackTrace();
} finally {
// 返还到连接池
returnResource(jedis);
}
} /**
* 删除以某字符串为前缀的key集合
*/
public <T> boolean delKeysMatch(String keyMatch) {
Jedis jedis = null;
try {
jedis = getJedis();
Set<String> keys = jedis.keys(keyMatch + "*");
Iterator<String> it = keys.iterator();
while (it.hasNext()) {
String keyStr = it.next();
jedis.del(keyStr);
}
return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
//返还到连接池
returnResource(jedis);
}
return false;
}
}
RedisClientUtil
redis缓存工具类,提供序列化接口的更多相关文章
- redis缓存工具类
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis ...
- spring boot 结合Redis 实现工具类
自己整理了 spring boot 结合 Redis 的工具类引入依赖 <dependency> <groupId>org.springframework.boot</g ...
- Go/Python/Erlang编程语言对比分析及示例 基于RabbitMQ.Client组件实现RabbitMQ可复用的 ConnectionPool(连接池) 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil 分享基于MemoryCache(内存缓存)的缓存工具类,C# B/S 、C/S项目均可以使用!
Go/Python/Erlang编程语言对比分析及示例 本文主要是介绍Go,从语言对比分析的角度切入.之所以选择与Python.Erlang对比,是因为做为高级语言,它们语言特性上有较大的相似性, ...
- 最全的Java操作Redis的工具类,使用StringRedisTemplate实现,封装了对Redis五种基本类型的各种操作!
转载自:https://github.com/whvcse/RedisUtil 代码 ProtoStuffSerializerUtil.java import java.io.ByteArrayInp ...
- Java 使用Redis缓存工具的图文详细方法
开始在 Java 中使用 Redis 前, 我们需要确保已经安装了 redis 服务及 Java redis 驱动,且你的机器上能正常使用 Java. (1)Java的安装配置可以参考我们的 Java ...
- Cache【硬盘缓存工具类(包含内存缓存LruCache和磁盘缓存DiskLruCache)】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 内存缓存LruCache和磁盘缓存DiskLruCache的封装类,主要用于图片缓存. 效果图 代码分析 内存缓存LruCache和 ...
- 分享基于MemoryCache(内存缓存)的缓存工具类,C# B/S 、C/S项目均可以使用!
using System; using System.Collections.Generic; using System.Linq; using System.Runtime.Caching; usi ...
- 封装php redis缓存操作类
封装php redis缓存操作类,集成了连接redis并判断连接是否成功,redis数据库选择,检测redis键是否存在,获取值,写入值,设置生存时间和删除清空操作. php redis类代码: &l ...
- 反射工具类.提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class,被AOP过的真实类等工具函数.java
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.Validate; import org.ap ...
随机推荐
- Android-Kotlin-继承
上一篇博客 Android-Kotlin-配置/入门 配置好了 AndroidStudio Kotlin 的环境: 1.先看一个案例,子类使用到父类的资源 [案例一] 父类 张翠山: package ...
- play framework - 初识
背景 研发代码框架是play-framework框架,想看代码的话,需要学习下play框架.IDE工具的话之前一直用的idea,所以本文涉及的idea play的配置 和 一些play的简单知识 认识 ...
- asp.net core mvc 中间件之路由
asp.net core mvc 中间件之路由 路由中间件 首先看路由中间件的源码 先用httpContext实例化一个路由上下文,然后把中间件接收到的路由添加到路由上下文的路由集合 然后把路由上下文 ...
- NET npoi帮助类
nuget添加npoi /// <summary> /// npoi帮助类 /// </summary> public static class NpoiHelper { // ...
- 设计模式《JAVA与模式》之解释器模式
在阎宏博士的<JAVA与模式>一书中开头是这样描述解释器(Interpreter)模式的: 解释器模式是类的行为模式.给定一个语言之后,解释器模式可以定义出其文法的一种表示,并同时提供一个 ...
- Testing - 软件测试知识梳理 - 软件可靠性测试
软件可靠性的基本概念 错误,缺陷,故障和失效 错误:指的是软件在生命周期中各个阶段的状态和行为与人们的期待不一致的偏差,不单单是软件系统本身,中间产品的偏差也算是软件错误 缺陷:指的是软件中一切不好的 ...
- 阿里云RDS数据库备份文件恢复到本地数据库
参考这里:https://help.aliyun.com/knowledge_detail/41817.html 第4.2步要多注释掉一些(应该根据实际报错来注释): [mysqld] innodb_ ...
- 利用Makefile安装helloworld模块(速成)
这学期对了一门操作系统,满怀着好奇装了虚拟机然后安了Ubuntu,这周作业是编译内核和安装个模块,妈耶,折腾了我一两天.终于弄完,CSDN上有挺多类似的教程,例如陈皓的跟我一起写Makefile,写的 ...
- Ubuntu 12.04 安装Redis并设置主从复制
今天想在Ubuntu上安装一个Redis服务器并配置Master-Slave,一开始懒得连VPN就查了一些国内的文章,不知道是没有亲自验证过的转载文章,还是版本问题造成的,发现按照步骤都没能成功完成配 ...
- vue教程2-01 vue生命周期、钩子函数
vue教程2-01 vue生命周期.钩子函数 <!DOCTYPE html> <html lang="en"> <head> <meta ...