使用Redis模拟简单验证码

要求

1.输入手机号,随机生成6位验证码,2分钟有效
2.验证验证码,返回成功或失败
3.每个手机一天只能发送三次

实现过程

1.随机生成验证码,(使用Random类)

 public static String getCode() {
    
    
        Random random=new Random();
        String code="";
        for(int i=0;i<6;i++) {
    
    
            int rand=random.nextInt(10);
            code+=rand;
        }
        return code;
    }

2.将验证码放到redis中,设置过期时间,设置三次以后不能再继续访问

public static void verifyCode(String phone) {
    
    
        //连接redis
        Jedis jedis=new Jedis("服务器的ip地址",6379);
        String countKey=null;
        String codeKey=null;
        String count=jedis.get(countKey);
        //如果还没有发送过验证码
        if(count==null) {
    
    
            //设置发送次数为1,将countKey的值设置为1,有效时间为1天
            jedis.setex(countKey,24*60*60,"1");
        }//少于三次,count每次加1
        else if(Integer.parseInt(count)<=2) {
    
    
            //发送次数+1,countKey的值自增
            jedis.incr(countKey);
        }
        else {
    
    
//超过三次,直接关闭jedis,并且返回,不再执行后面的将验证码放入到redis中的步骤
            System.out.println("今天发送次数已经超过三次");
            jedis.close();
            return ;
        }
        //将验证码放到redis里面
        String vcode=getCode();
        //将codeKey的值设置为vcode,即就是验证码,并且设置过期时间为两分钟
        jedis.setex(codeKey,120,vcode);
        jedis.close();
    }

3.校验验证码

 public static void getRedisCode(String phone,String code) {
    
    
        Jedis jedis=new Jedis("服务器IP地址",6379);
        //通过key来获取验证码
        String codeKey="code";
        String redisCode=jedis.get(codeKey);
        //判断
        if(redisCode.equals(code)) {
    
    
            System.out.println("成功");
        }
        else {
    
    
            System.out.println("失败");
        }
        jedis.close();
    }

运行

1.先输入手机号
在这里插入图片描述
然后进入到Xshell里,使用get语句,得到验证码

在这里插入图片描述

然后注释掉verifyCode(“18291346654”);防止它重新发送验证码,调用校验验证码函数完成校验

在这里插入图片描述

最后得到结果
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_51656756/article/details/121843328
今日推荐