“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 分钟前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天29 分钟前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
桌面运维家1 小时前
如何用半缓存云桌面将服务器硬盘容量扩展至本地终端?
运维·服务器·缓存
南墙上的石头2 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
画中有画2 小时前
论向量数据库在项目中的应用
数据库
spider_xcxc3 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
l1t4 小时前
在linux和windows中解决duckdb 1.6dev版本输出执行计划报错问题
linux·运维·数据库·windows·duckdb
执子手 吹散苍茫茫烟波4 小时前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql
落叶-IT4 小时前
Java异常处理深度实战教程:异常传播的失败场景分析
数据库·oracle
搬砖柯5 小时前
系列10-接口/UI 自动化怎么验落库?数据工厂与数据库断言实践
数据库·测试工具·ui·开源·自动化