spring boot结合Redis实现工具类的方法示例
更新时间:2018年11月25日 08:43:58 作者:兰茗翔
这篇文章主要介绍了spring boot结合Redis实现工具类的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
自己整理了 spring boot 结合 Redis 的工具类
引入依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
加入配置
# Redis数据库索引(默认为0) spring.redis.database=0 # Redis服务器地址 spring.redis.host=localhost # Redis服务器连接端口 spring.redis.port=6379
实现代码
这里用到了 静态类工具类中 如何使用 @Autowired
package com.lmxdawn.api.common.utils; import java.util.Collection; import java.util.Set; import java.util.concurrent.TimeUnit; import javax.annotation.PostConstruct; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; /** * 缓存操作类 */ @Component public class CacheUtils { @Autowired private RedisTemplate<String, String> redisTemplate; // 维护一个本类的静态变量 private static CacheUtils cacheUtils; @PostConstruct public void init() { cacheUtils = this; cacheUtils.redisTemplate = this.redisTemplate; } /** * 将参数中的字符串值设置为键的值,不设置过期时间 * @param key * @param value 必须要实现 Serializable 接口 */ public static void set(String key, String value) { cacheUtils.redisTemplate.opsForValue().set(key, value); } /** * 将参数中的字符串值设置为键的值,设置过期时间 * @param key * @param value 必须要实现 Serializable 接口 * @param timeout */ public static void set(String key, String value, Long timeout) { cacheUtils.redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS); } /** * 获取与指定键相关的值 * @param key * @return */ public static Object get(String key) { return cacheUtils.redisTemplate.opsForValue().get(key); } /** * 设置某个键的过期时间 * @param key 键值 * @param ttl 过期秒数 */ public static boolean expire(String key, Long ttl) { return cacheUtils.redisTemplate.expire(key, ttl, TimeUnit.SECONDS); } /** * 判断某个键是否存在 * @param key 键值 */ public static boolean hasKey(String key) { return cacheUtils.redisTemplate.hasKey(key); } /** * 向集合添加元素 * @param key * @param value * @return 返回值为设置成功的value数 */ public static Long sAdd(String key, String... value) { return cacheUtils.redisTemplate.opsForSet().add(key, value); } /** * 获取集合中的某个元素 * @param key * @return 返回值为redis中键值为key的value的Set集合 */ public static Set<String> sGetMembers(String key) { return cacheUtils.redisTemplate.opsForSet().members(key); } /** * 将给定分数的指定成员添加到键中存储的排序集合中 * @param key * @param value * @param score * @return */ public static Boolean zAdd(String key, String value, double score) { return cacheUtils.redisTemplate.opsForZSet().add(key, value, score); } /** * 返回指定排序集中给定成员的分数 * @param key * @param value * @return */ public static Double zScore(String key, String value) { return cacheUtils.redisTemplate.opsForZSet().score(key, value); } /** * 删除指定的键 * @param key * @return */ public static Boolean delete(String key) { return cacheUtils.redisTemplate.delete(key); } /** * 删除多个键 * @param keys * @return */ public static Long delete(Collection<String> keys) { return cacheUtils.redisTemplate.delete(keys); } }
相关地址
GitHub 地址:https://github.com/lmxdawn/vue-admin-java
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
elasticsearch集群cluster discovery可配式模块示例分析
这篇文章主要为大家介绍了elasticsearch集群cluster discovery可配式模块示例分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-04-04SpringCloud Gateway的熔断限流配置实现方法
Spring Cloud Gateway支持通过配置熔断和限流机制来保证服务的稳定性和可用性,可通过Hystrix和Resilience4j两种方式实现。Hystrix通过注解和配置文件实现熔断限流,Resilience4j通过编程式配置实现2023-04-04springboot2.1.7去除json返回字段中为null的字段
这篇文章主要介绍了springboot2.1.7去除json返回字段中为null的字段,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-12-12Java远程执行shell命令出现java: command not found问题及解决
这篇文章主要介绍了Java远程执行shell命令出现java: command not found问题及解决方案,具有很好的参考价值,希望对大家有所帮助。2023-07-07
最新评论