“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 超三次发送验证码

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

相关推荐
骑士雄师1 小时前
使用 IntelliJ IDEA 结合 DBeaver 连接 MySQL 数据库并实现数据增删查改的详细步骤:
数据库·mysql·intellij-idea
呼哧呼哧.6 小时前
Spring的核心思想与注解
数据库·sql·spring
迎風吹頭髮7 小时前
Linux内核架构浅谈49-Linux per-CPU页面缓存:热页与冷页的管理与调度优化
linux·缓存·架构
21号 17 小时前
9.Redis 集群(重在理解)
数据库·redis·算法
爬山算法7 小时前
Redis(73)如何处理Redis分布式锁的死锁问题?
数据库·redis·分布式
嘗_7 小时前
sql特训
数据库·sql
jason.zeng@15022078 小时前
centos中安装redis
linux·redis·centos
码农多耕地呗8 小时前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存
wan5555cn8 小时前
周末之美:慢下来,拥抱生活的温柔
数据库
yumgpkpm9 小时前
华为鲲鹏 Aarch64 环境下多 Oracle 、mysql数据库汇聚到Cloudera CDP7.3操作指南
大数据·数据库·mysql·华为·oracle·kafka·cloudera