要求
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”);防止它重新发送验证码,调用校验验证码函数完成校验
最后得到结果