您当前的位置:首页 > 电脑百科 > 数据库 > Redis

在Java中使用Redis的方法

时间:2022-06-30 11:12:05  来源:  作者:杂文论

前提

可供访问的redis服务器 可以自己在本地启动虚拟机

如何在本地启动一个Redis参考bilibili尚硅谷Redis6

SpringBoot项目中需要添加的依赖

<dependency>

<groupId>redis.clients</groupId>

<artifactId>jedis</artifactId>

<version>3.2.0</version>

</dependency>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>RELEASE</version>

<scope>compile</scope>

</dependency>

常见的用法

工具类 用于获取Redis连接

public class JedisUtils {

public static Jedis getJedisClient(){

Jedis jedis = new Jedis("192.168.110.101",6379);

return jedis;

}

}

检测本地Redis是否可以使用

@Test

public void pingTest(String[] args) {

Jedis jedis = new Jedis("192.168.110.101",6379);

String ping = jedis.ping();

// 当Redis能使用时 会输出pong

System.out.println(ping);

}

关于Redis String 类型的API

@Test

public void StringTest(){

Jedis jedis = new Jedis("192.168.110.101",6379);

jedis.set("name","lucy");

//redis 批量添加多个k v ?

jedis.mset("k1","v1","k2","v2");

List<String> mget = jedis.mget("k1", "k2");

String name = jedis.get("name");

System.out.println(name);

}

关于Jedis set 类型API

@Test

public void setTest(){

//操作set 集合

Jedis jedisClient = JedisUtils.getJedisClient();

//set中添加元素

jedisClient.sadd("name1","lucy","mary","jack");

Set<String> name = jedisClient.smembers("name1");

//set中删除元素

jedisClient.srem("name1","lucy");

Set<String> name1 = jedisClient.smembers("name1");

System.out.println(name1);

System.out.println(name);

}

关于Jedis hash类型的API

@Test

public void hashTest(){

// hash的两种添加值方式以及取值方式

Jedis jedisClient = JedisUtils.getJedisClient();

jedisClient.hset("hset","lucy","20");

String hget = jedisClient.hget("hset", "lucy");

System.out.println(hget);

Map<String,String> hashTsetMap = new HashMap<>(16);

hashTsetMap.put("jack","30");

jedisClient.hset("hset",hashTsetMap);

List<String> age = jedisClient.hmget("hset","lucy");

System.out.println(age);

jedisClient.hdel("hset","lucy");

String lucy = jedisClient.hget("hset", "lucy");

System.out.println(lucy);

}

zSet类型API

@Test

public void zSetTest(){

Jedis jedisClient = JedisUtils.getJedisClient();

jedisClient.zadd("china",100d,"shanghAI");

Set<String> china = jedisClient.zrange("china", 0, -1);

System.out.println(china);

}

使用Redis实现一个简易版短信注册功能

/**

* 注册功能

* 生成手机验证码 且五分钟内有效

* 1.连接redis

* 2.判断验证码生成的次数

* 3.生成验证码 调用短信发送API

* 4.前台回传验证码 ,校验验证码的有效性

* 5.注册成功

* @param args

*/

//

public void getMessage() {

try (Jedis jedisClient=JedisUtils.getJedisClient()){

String phone = "12345678";

if (getGenerateTimes(phone,jedisClient)){

String verificationCode = getVerificationCode(phone, jedisClient);

System.out.println(verificationCode);

}else {

System.out.println("超过短信次数");

}

} catch (Exception e) {

e.printStackTrace();

}

}

public static final String KEY = "generateTime";

public static final Integer Max_TIME = 2;

public static final Integer MINI_TIME = 0;

// 计算一天发送短信的次数 不能超过三次

public static boolean getGenerateTimes(String phone, Jedis client){

String times = client.get(phone+KEY);

if (times==null){

client.setex(phone+KEY, 24*60*60,MINI_TIME.toString());

}

// 使用Interger.valueOf不能转换?

//基本类的包装类无法自动拆箱进行相互比较

if (Integer.parseInt(times)>Max_TIME.intValue()){

return false;

}

client.incr(phone+KEY);

return true;

}

/**

* 生成六位数验证码 调用api发送短信到手机

* @param phone

* @param client

* @return

*/

public static String getVerificationCode(String phone, Jedis client){

Random random = new Random();

StringBuffer stringBuffer = new StringBuffer();

// 有更好的方法生成六位随机数

for (int j = 0; j < 6; j++) {

stringBuffer.Append(random.nextInt(10));

}

// 调用短信API发送 并做对应的业务判断

// 发送短信成功 将数据放入redis 并设置过期时间为五分钟

String setex = client.setex(phone, 300, stringBuffer.toString());

return stringBuffer.toString();

}

public static Boolean verification(String phone, String code, Jedis client){

String storeCode = client.get(phone);

if (code!=null&&code.equals(storeCode)){

return Boolean.TRUE;

}

return Boolean.FALSE;

}

@Test

public void verificationTest(){

try(Jedis jedisClient = JedisUtils.getJedisClient()) {

if (verification("12345678","465481",jedisClient)){

System.out.println("校验成功");

}else {

System.out.println("校验失败");

}

}

}



Tags:Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
兄弟,王者荣耀的段位排行榜是通过Redis实现的?
在王者荣耀中,我们会打排位赛,而且大家最关注的往往都是你的段位,还有在好友中的排名。作为程序员的你,是否思考过这个段位排行榜是怎么实现的?了解它的实现原理,会不会对上分有所...【详细内容】
2024-04-15  Search: Redis  点击:(3)  评论:(0)  加入收藏
16个Redis常见使用场景总结
来源:blog.csdn.net/qq_39938758/article/details/105577370目录 缓存 数据共享分布式 分布式锁 全局ID 计数器 限流 位统计 购物车 用户消息时间线timeline 消息...【详细内容】
2024-04-11  Search: Redis  点击:(8)  评论:(0)  加入收藏
Linux获取Redis 性能指标方法
一、监控指标&Oslash; 性能指标:Performance&Oslash; 内存指标: Memory&Oslash; 基本活动指标:Basic activity&Oslash; 持久性指标: Persistence&Oslash; 错误指标:Error二、监...【详细内容】
2024-04-11  Search: Redis  点击:(10)  评论:(0)  加入收藏
Redis与缓存一致性问题
缓存一致性问题是在使用缓存系统,如Redis时经常遇到的问题。当数据在原始数据源(如数据库)中发生变化时,如何确保缓存中的数据与数据源保持一致,是开发者需要关注的关键问题。一...【详细内容】
2024-04-11  Search: Redis  点击:(8)  评论:(0)  加入收藏
Redis 不再 “开源”,未来采用 SSPLv1 和 RSALv2 许可证
Redis 官方于21日宣布修改开源协议 &mdash;&mdash; 未来所有版本都将使用 “源代码可用” 的许可证 (source-available licenses)。具体来说,Redis 将不再遵循 BSD 3-Clause...【详细内容】
2024-03-27  Search: Redis  点击:(25)  评论:(0)  加入收藏
Redis“叛逃”开源,得罪了几乎所有人
内存数据库供应商Redis近日在开源界砸下了一块“巨石”。Redis即将转向双许可模式,并实施更为严格的许可条款。官方对此次变更的公告直截了当:从Redis 7.4版本开始,Redis将在Re...【详细内容】
2024-03-25  Search: Redis  点击:(13)  评论:(0)  加入收藏
如何使用 Redis 实现消息队列
Redis不仅是一个强大的内存数据存储系统,它还可以用作一个高效的消息队列。消息队列是应用程序间或应用程序内部进行异步通信的一种方式,它允许数据生产者将消息放入队列中,然...【详细内容】
2024-03-22  Search: Redis  点击:(22)  评论:(0)  加入收藏
Redis不再 “开源”
Redis 官方今日宣布修改开源协议 &mdash;&mdash; 未来所有版本都将使用 “源代码可用” 的许可证 (source-available licenses)。具体来说,Redis 将不再遵循 BSD 3-Clause 开...【详细内容】
2024-03-21  Search: Redis  点击:(15)  评论:(0)  加入收藏
在Redis中如何实现分布式锁的防死锁机制?
在Redis中实现分布式锁是一个常见的需求,可以通过使用Redlock算法来防止死锁。Redlock算法是一种基于多个独立Redis实例的分布式锁实现方案,它通过协调多个Redis实例之间的锁...【详细内容】
2024-02-20  Search: Redis  点击:(50)  评论:(0)  加入收藏
手动撸一个 Redis 分布式锁
大家好呀,我是楼仔。今天第一天开工,收拾心情,又要开始好好学习,好好工作了。对于使用 Java 的小伙伴,其实我们完全不用手动撸一个分布式锁,直接使用 Redisson 就行。但是因为这些...【详细内容】
2024-02-19  Search: Redis  点击:(47)  评论:(0)  加入收藏
▌简易百科推荐
兄弟,王者荣耀的段位排行榜是通过Redis实现的?
在王者荣耀中,我们会打排位赛,而且大家最关注的往往都是你的段位,还有在好友中的排名。作为程序员的你,是否思考过这个段位排行榜是怎么实现的?了解它的实现原理,会不会对上分有所...【详细内容】
2024-04-15    dbaplus社群  Tags:Redis   点击:(3)  评论:(0)  加入收藏
16个Redis常见使用场景总结
来源:blog.csdn.net/qq_39938758/article/details/105577370目录 缓存 数据共享分布式 分布式锁 全局ID 计数器 限流 位统计 购物车 用户消息时间线timeline 消息...【详细内容】
2024-04-11    书圈  Tags:Redis   点击:(8)  评论:(0)  加入收藏
Linux获取Redis 性能指标方法
一、监控指标&Oslash; 性能指标:Performance&Oslash; 内存指标: Memory&Oslash; 基本活动指标:Basic activity&Oslash; 持久性指标: Persistence&Oslash; 错误指标:Error二、监...【详细内容】
2024-04-11  上海天正信息科技有限    Tags:Redis   点击:(10)  评论:(0)  加入收藏
Redis与缓存一致性问题
缓存一致性问题是在使用缓存系统,如Redis时经常遇到的问题。当数据在原始数据源(如数据库)中发生变化时,如何确保缓存中的数据与数据源保持一致,是开发者需要关注的关键问题。一...【详细内容】
2024-04-11  后端Q    Tags:Redis   点击:(8)  评论:(0)  加入收藏
Redis 不再 “开源”,未来采用 SSPLv1 和 RSALv2 许可证
Redis 官方于21日宣布修改开源协议 &mdash;&mdash; 未来所有版本都将使用 “源代码可用” 的许可证 (source-available licenses)。具体来说,Redis 将不再遵循 BSD 3-Clause...【详细内容】
2024-03-27  dbaplus社群    Tags:Redis   点击:(25)  评论:(0)  加入收藏
Redis“叛逃”开源,得罪了几乎所有人
内存数据库供应商Redis近日在开源界砸下了一块“巨石”。Redis即将转向双许可模式,并实施更为严格的许可条款。官方对此次变更的公告直截了当:从Redis 7.4版本开始,Redis将在Re...【详细内容】
2024-03-25    51CTO  Tags:Redis   点击:(13)  评论:(0)  加入收藏
如何使用 Redis 实现消息队列
Redis不仅是一个强大的内存数据存储系统,它还可以用作一个高效的消息队列。消息队列是应用程序间或应用程序内部进行异步通信的一种方式,它允许数据生产者将消息放入队列中,然...【详细内容】
2024-03-22  后端Q  微信公众号  Tags:Redis   点击:(22)  评论:(0)  加入收藏
Redis不再 “开源”
Redis 官方今日宣布修改开源协议 &mdash;&mdash; 未来所有版本都将使用 “源代码可用” 的许可证 (source-available licenses)。具体来说,Redis 将不再遵循 BSD 3-Clause 开...【详细内容】
2024-03-21  OSC开源社区    Tags:Redis   点击:(15)  评论:(0)  加入收藏
在Redis中如何实现分布式锁的防死锁机制?
在Redis中实现分布式锁是一个常见的需求,可以通过使用Redlock算法来防止死锁。Redlock算法是一种基于多个独立Redis实例的分布式锁实现方案,它通过协调多个Redis实例之间的锁...【详细内容】
2024-02-20  编程技术汇    Tags:Redis   点击:(50)  评论:(0)  加入收藏
手动撸一个 Redis 分布式锁
大家好呀,我是楼仔。今天第一天开工,收拾心情,又要开始好好学习,好好工作了。对于使用 Java 的小伙伴,其实我们完全不用手动撸一个分布式锁,直接使用 Redisson 就行。但是因为这些...【详细内容】
2024-02-19  楼仔  微信公众号  Tags:Redis   点击:(47)  评论:(0)  加入收藏
站内最新
站内热门
站内头条