Redis(十六)-Jedis案例-模拟验证码发送

Redis(十六)-Jedis案例-模拟验证码发送,第1张

您好,我是码农飞哥,感谢您阅读本文,欢迎一键三连哦。
💪🏻 1. Python基础专栏,基础知识一网打尽,9.9元买不了吃亏,买不了上当。 Python从入门到精通
❤️ 2. Python爬虫专栏,系统性的学习爬虫的知识点。9.9元买不了吃亏,买不了上当 。python爬虫入门进阶
❤️ 3. Ceph实战,从原理到实战应有尽有。 Ceph实战
❤️ 4. Java高并发编程入门,打卡学习Java高并发。 Java高并发编程入门
😁 5. 社区逛一逛,周周有福利,周周有惊喜。码农飞哥社区,飞跃计划
全网同名【码农飞哥】欢迎关注,个人VX: wei158556

文章目录
    • 简介
    • 代码编写
    • 验证用户输入的验证码
    • 总结

简介

本次模拟验证码发送的需求有三项:

  1. 输入手机号,点击发送后随机生成6位数字验证码,2分钟有效
  2. 输入验证码,点击验证,返回成功或失败
  3. 每个手机号每天只能输入3次
代码编写
  1. 利用Random函数生成6位随机数
    public String generateCode() {
        StringBuilder code = new StringBuilder();
        for (int i = 0; i < 6; i++) {
            int nextInt = new Random().nextInt(10);
            code.append(nextInt);
        }
        return code.toString();
    }
  1. 输入手机号,获取验证码并将验证码存放到Redis中。同时,还需要校验验证码的发送是否超过限制。
public String setCode(String phone) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        String code = generateCode();
        String key = "code:" + phone;
        String code_count = "code:" + phone + ":count";
        String count = jedis.get(code_count);
        if (count == null) {
            //第一次设置
            jedis.setex(code_count, 24 * 60 * 60L, "1");
        } else if (Integer.valueOf(count) <= 2) {
        	//验证码的次数+1
            jedis.incr(code_count);
        } else {
            System.out.println("每个手机号每天只能输入3次");
            return "每个手机号每天只能输入3次";
        }
        jedis.setex(key,2*60L, code);
        return code;
    }

这里通过设置键 "code:" + phone + ":count" 来统计每个手机号每天发送的次数,此处采用的是setex方法进行设置,设置的键是"code:" + phone , 设置的过期时间是1天,即24 * 60 * 60L秒,设置的值是"1"。
第一次设置时值count为空,需要手动设置,后面再次设置时就能获取到值了,通过incr 方法对验证码的次数进行+1 *** 作。直到值count大于3时,则给出提示:每个手机号每天只能输入3次。
3. 设置生成的随机验证码,键是"code:" + phone,值是生成的code,过期时间是2分钟,即2*60L秒。

验证用户输入的验证码

验证用户输入的验证码就是将用户输入的验证码和Redis中保存的验证码做一个对比。如果两者一样的话则表示验证成功,否则表示验证失败。

  public boolean verifyCode(String phone, String code) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        String redis_code = jedis.get("code:" + phone);
        if (redis_code != null && code.equals(redis_code)) {
            System.out.println("验证码验证成功");
            return true;
        }
        System.out.println("验证码验证失败");
        return false;
    }

如果redis_code为空,则表示验证码已经过期,故不能在使用,如果Redis中保存的验证码redis_code和用户输入的验证码code相等则表示验证码验证成功。

总结

本文通过模拟实际场景中的验证码发送需求重温了一遍Jedis的使用,希望对读者朋友们有所帮助。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/798586.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-06
下一篇 2022-05-06

发表评论

登录后才能评论

评论列表(0条)

保存