“Jedis与Redis整合指南:实现高效的Java应用与Redis交互“

目录

[#. 概念](#. 概念)

[1. 导入jedis依赖](#1. 导入jedis依赖)

[2. 写一个类(ping通redis)](#2. 写一个类(ping通redis))

[3. String字符串使用](#3. String字符串使用)

[3.1 set,get方法使用(设值,取值)](#3.1 set,get方法使用(设值,取值))

[3.2 mset,mget方法使用(设置多个值,取多个值)](#3.2 mset,mget方法使用(设置多个值,取多个值))

[4. list列表使用](#4. list列表使用)

[5. Set集合使用](#5. Set集合使用)

[6. hash哈希](#6. hash哈希)

[7. Zset有序集合](#7. Zset有序集合)

[8. Jedis案例(模拟验证码发送)](#8. Jedis案例(模拟验证码发送))

[8.1 代码](#8.1 代码)

[8.2 第一次发送验证码](#8.2 第一次发送验证码)

[8.3 超三次发送验证码](#8.3 超三次发送验证码)


#. 概念

  • Jedis就是集成了redis的一些命令操作,封装了redis的Java客户端。提供了连接池管理。一般不直接使用Jedis,而是在其上在封装一层,作为业务的使用,如果用spring的话,可以看看spring封装的redis Spring Data Redis
  • 通过Java可以对Redis6进行操作;

1. 导入jedis依赖

XML 复制代码
    <dependencies>
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.2.0</version>
        </dependency>
    </dependencies>

2. 写一个类(ping通redis)

java 复制代码
    public static void main(String[] args) {

        // 创建Jedis对象  本机地址或(远程redis的地址,端口号)
        Jedis jedis = new Jedis("127.0.0.1",6379);

        // 测试
        String value = jedis.ping();
        System.out.println(value);
    }

前提:要确保redis客户端要正常运行;

3. String字符串使用

3.1 set,get方法使用(设值,取值)
java 复制代码
    @Test
    public void demo() {
        Jedis jedis = new Jedis("xxx.x.x.xx", 6379);
        jedis.set("user1","zhangsan");
        jedis.set("user2","yiyi");
        String user1 = jedis.get("user1");
        System.out.println(user1);
        Set<String> keys = jedis.keys("*");
        for (String key : keys) {
            System.out.println(key);
        }
    }
3.2 mset,mget方法使用(设置多个值,取多个值)
java 复制代码
jedis.mset("k1", "v1", "k2", "v2");
List<String> mget = jedis.mget("k1", "k2");
System.out.println(mget);

// 输出[v1, v2]

4. list列表使用

key1是key,其它的是它的值;

java 复制代码
    public static void main(String[] args) {

        // 创建Jedis对象  本机地址或(远程redis的地址,端口号)
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        jedis.lpush("key1", "lucy", "mary", "jack");
        List<String> key1 = jedis.lrange("key1", 0, -1);
        System.out.println(key1);

    }

5. Set集合使用

java 复制代码
    public static void main(String[] args) {

        // 创建Jedis对象  本机地址或(远程redis的地址,端口号)
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        jedis.sadd("names", "lucy");
        jedis.sadd("names", "mary");

        Set<String> names = jedis.smembers("names");
        System.out.println(names);

    }

6. hash哈希

java 复制代码
    public static void main(String[] args) {

        // 创建Jedis对象  本机地址或(远程redis的地址,端口号)
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        jedis.hset("users", "age", "20");
        String users = jedis.hget("users", "age");
        System.out.println(users);

    }

7. Zset有序集合

java 复制代码
    public static void main(String[] args) {

        // 创建Jedis对象  本机地址或(远程redis的地址,端口号)
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        jedis.zadd("china", 100d, "hangzhou");
        Set<String> china = jedis.zrange("china", 0, -1);
        System.out.println(china);

    }

8. Jedis案例(模拟验证码发送)

  • 需求:
    1. 输入手机号,点击发送后随机生成6位数字码,5分钟有效;
    2. 输入验证码,点击验证,返回成功或失败;
    3. 每个手机号每天只能输入3次;
8.1 代码
java 复制代码
    /**
     * 1.生成6位数验证码
     *
     * @return code:6位数
     */
    public static String getCode() {
        Random random = new Random();
        String code = "";
        for (int i = 0; i < 6; i++) {
            int nextInt = random.nextInt(10);
            code += nextInt;
        }
        return code;
    }


    /**
     * 2.每个手机每天只能发送三次,验证码发送到redis中,设置过期时间5分钟
     *
     * @param phone 电话
     */
    public static String verifyCode(String phone) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        // 一天内发送的次数:countKey
        // 发送的验证码:codeKey
        String countKey = "VerifyCode" + phone + ":count";
        String codeKey = "VerifyCode" + phone + ":code";

        String count = jedis.get(countKey);

        if (null == count) {  // 1.没有发送次数,第一个发送,发送次数是1,
            jedis.setex(countKey, 24 * 60 * 60, "1");
        } else if (Integer.parseInt(count) > 2) {  // 2.发送第三次,不可再次发送
            System.out.println("今天已发送3次,即将超数,请停止");
            jedis.close();
            return " ";
        } else if (Integer.parseInt(count) < 3) {  // 3.发送次数加1
            jedis.incr(countKey);
        }
        // 发送验证码到redis里面,五分钟超时
        String code = getCode();
        jedis.setex(codeKey, 300, code);
        jedis.close();
        return "第" + jedis.get(countKey) + "次发送的验证码是:" + code;
    }

    /**
     * 3.验证码校验
     *
     * @param phone 电话
     * @param code  验证码
     */
    public static void getRedisCode(String phone, String code) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);

        // 从redis获取验证码
        String codeKey = "VerifyCode" + phone + ":code";
        String redisCode = jedis.get(codeKey);
        System.out.println(redisCode);
        if (redisCode.equals(code)) {
            System.out.println("验证成功");
        } else {
            System.out.println("验证失败");
        }
        jedis.close();
    }


    // 4.模拟验证码发送
    public static void main(String[] args) {

        // 1.发送验证码
        String vcode = verifyCode("18300000014");
        System.out.println(vcode);
        // 2.通过验证校验
        // getRedisCode("18300000000", "182327");
    }
8.2 第一次发送验证码
  1. 执行过程
  1. redis缓存

count是发送次数;

code是发送验证发;

  1. 验证码校验
8.3 超三次发送验证码

解释:超出三次验证码发送,即停止验证码推送;

相关推荐
forestsea15 分钟前
全解:Redis RDB持久化和AOF持久化
数据库·redis·缓存
叫我DPT16 分钟前
分享一个python启动文件脚本(django示例)
数据库·python·django
小五Z1 小时前
Redis--事务
redis·分布式·后端·缓存
XXYBMOOO1 小时前
基于 Qt 的 BMP 图像数据存取至 SQLite 数据库的实现
数据库·c++·qt
Sunlight_7771 小时前
第五章 SQLite数据库:1、SQLite 基础语法及使用案例
java·linux·服务器·jvm·数据库·tcp/ip·sqlite
JhonKI1 小时前
【从零实现高并发内存池】内存池整体框架设计 及 thread cache实现
java·redis·缓存
嘉嘉king2 小时前
Mysql联表查询
数据库
镜舟科技2 小时前
NoSQL 与 NewSQL 全面对比:如何选择适合你的数据库方案?
数据库·starrocks·nosql·newsql·技术架构·实时数据分析
TDengine (老段)2 小时前
TDengine 语言连接器(Node.js)
大数据·c语言·数据库·物联网·node.js·时序数据库·tdengine
洛神灬殇3 小时前
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 时间事件处理部分)
redis·后端