redis 缓存使用

工具类

复制代码
package org.springblade.questionnaire.redis;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;

import java.util.Map;
import java.util.concurrent.TimeUnit;

@Service
public class RedisService {

	@Autowired
	private StringRedisTemplate stringRedisTemplate;

	private final ObjectMapper objectMapper = new ObjectMapper();

	// 存储对象到Redis
	public void setObjectToRedis(String key, Object obj) {
		try {
			// 将对象序列化为JSON字符串
			String value = objectMapper.writeValueAsString(obj);
			// 使用StringRedisTemplate将JSON字符串存储到Redis
			stringRedisTemplate.opsForValue().set(key, value);
		} catch (JsonProcessingException e) {
			throw new RuntimeException("Failed to serialize object to JSON", e);
		}
	}

	// 从Redis获取对象
	public <T> T getObjectFromRedis(String key, Class<T> clazz) {
		String json = stringRedisTemplate.opsForValue().get(key);
		if (json != null) {
			try {
				// 将JSON字符串反序列化为对象
				return objectMapper.readValue(json, clazz);
			} catch (Exception e) {
				throw new RuntimeException("Failed to deserialize JSON to object", e);
			}
		}
		return null;
	}

	// 存储对象数组到Redis
	public <T> void setArrayToRedis(String key, T[] array) {
		try {
			// 将对象数组序列化为JSON字符串
			String value = objectMapper.writeValueAsString(array);
			// 使用StringRedisTemplate将JSON字符串存储到Redis
			stringRedisTemplate.opsForValue().set(key, value);
		} catch (JsonProcessingException e) {
			throw new RuntimeException("Failed to serialize object array to JSON", e);
		}
	}

	// 从Redis获取对象数组
	@SuppressWarnings("unchecked")
	public <T> T[] getArrayFromRedis(String key, Class<T[]> clazz) {
		String json = stringRedisTemplate.opsForValue().get(key);
		if (json != null) {
			try {
				// 将JSON字符串反序列化为对象数组
				return objectMapper.readValue(json, clazz);
			} catch (Exception e) {
				throw new RuntimeException("Failed to deserialize JSON to object array", e);
			}
		}
		return null;
	}

	// 存储对象到Redis并设置过期时间
	public void setObjectToRedisWithTime(String key, Object obj, long timeout, TimeUnit timeUnit) {
		try {
			// 将对象序列化为JSON字符串
			String value = objectMapper.writeValueAsString(obj);
			// 使用StringRedisTemplate将JSON字符串存储到Redis并设置过期时间
			stringRedisTemplate.opsForValue().set(key, value, timeout, timeUnit);
		} catch (JsonProcessingException e) {
			throw new RuntimeException("Failed to serialize object to JSON", e);
		}
	}

	// 存储对象数组到Redis并设置过期时间
	public <T> void setArrayToRedisWithTime(String key, T[] array, long timeout, TimeUnit timeUnit) {
		try {
			// 将对象数组序列化为JSON字符串
			String value = objectMapper.writeValueAsString(array);
			// 使用StringRedisTemplate将JSON字符串存储到Redis并设置过期时间
			stringRedisTemplate.opsForValue().set(key, value, timeout, timeUnit);
		} catch (JsonProcessingException e) {
			throw new RuntimeException("Failed to serialize object array to JSON", e);
		}
	}

	// 存储字符串到Redis并设置过期时间
	public void setStringToRedis(String key, String value, long timeout, TimeUnit timeUnit) {
		// 使用StringRedisTemplate将字符串存储到Redis并设置过期时间
		stringRedisTemplate.opsForValue().set(key, value, timeout, timeUnit);
	}

	// 从Redis获取字符串
	public String getStringFromRedis(String key) {
		return stringRedisTemplate.opsForValue().get(key);
	}


	// 存储 Map<String, Map<String, String>> 到 Redis 并设置过期时间
	public void setTranslationsToRedis(String key, Map<String, Map<String, String>> translations, long timeout, TimeUnit timeUnit) {
		try {
			// 将 Map 序列化为 JSON 字符串
			String value = objectMapper.writeValueAsString(translations);
			// 使用 StringRedisTemplate 将 JSON 字符串存储到 Redis 并设置过期时间
			stringRedisTemplate.opsForValue().set(key, value, timeout, timeUnit);
		} catch (JsonProcessingException e) {
			throw new RuntimeException("Failed to serialize translations map to JSON", e);
		}
	}

	// 从 Redis 获取 Map<String, Map<String, String>>
	public Map<String, Map<String, String>> getTranslationsFromRedis(String key) {
		String json = stringRedisTemplate.opsForValue().get(key);
		if (json != null) {
			try {
				// 将 JSON 字符串反序列化为 Map<String, Map<String, String>>
				return objectMapper.readValue(json, new TypeReference<Map<String, Map<String, String>>>() {});
			} catch (Exception e) {
				throw new RuntimeException("Failed to deserialize JSON to translations map", e);
			}
		}
		return null;
	}
}

引用

复制代码
	@Autowired
	private RedisService redisService;

调用方法

一般设置过期时间一天,看情况而定

相关推荐
文心快码BaiduComate6 分钟前
Comate搭载DeepSeek-V4
前端·后端
189228048618 分钟前
NV231美光闪存MT29F32T08GWLBHD6-MES:B
大数据·服务器·人工智能·科技·缓存
豹哥学前端8 分钟前
5分钟搞懂事件委托
前端·javascript·面试
Awu122713 分钟前
🍎把数学公式搬进 Web 表格:一个 VTable 实战案例
前端
江无行者15 分钟前
aly oss技能应用
前端
朝阳3922 分钟前
单向数据流
前端
小小小小宇24 分钟前
H5 嵌入微信 / 支付宝 / 抖音小程序 WebView:调用原生能力完整方案
前端
卷帘依旧25 分钟前
React中父子组件生命周期的执行顺序
前端
绝世唐门三哥30 分钟前
ES6 --- import/export 全解析
开发语言·前端·javascript
小杍随笔30 分钟前
【iNovel 前端架构深度解析:基于 Vue 3 + TypeScript + Tauri 的跨端小说写作工具】
前端·架构·typescript