注意:
Jedis连接远程的redis服务器,首先:
①关掉防火墙
②确保远程访问:
redis.conf中,将bind 127.0.0.1注释掉
再将 protected-mode no,保护模式关掉。
1、功能需求
①输入手机号,点击发送后随机生成6位的随机数,2分钟内有效
②输入验证码,点击验证,返回成功或者失败
③每个手机号每天只能输入三次,也就是发送验证码发送三次。
2、需求分析
需求一,6位随机数,可以使用Random。
需求二,验证码2分钟内有效,可以将验证码加载到redis里面,设置过期时间为2分钟
需求三,每个手机号每天只能发送三次验证码。使用jedis中的incr对value,并判断。
需求四,判断输入的验证码和redis里面的验证码是否一致。从redis中取出,比较。
3、代码实现
package com.atguigu.jedis;
import redis.clients.jedis.Jedis;
import java.util.Random;
public class PhoneCode {
public static void main(String[] args) {
//verifyCode("13016237621");
getRedisCode("13016237621","759751");
}
// 1、生成6位10以内的数
public static String getCode(){
Random random = new Random();
// 0--9
String code = "";
for (int i = 0; i < 6; i++) {
int a = random.nextInt(10);
code += a;
}
return code;
}
// 2、将这个随机数添加到redis中,每个手机每天只能发送三次,设置过期时间
public static void verifyCode(String phone){
Jedis jedis = new Jedis("192.168.8.134", 6379);
// 手机发送的次数
String countKey = "VerifyCode" + phone + ":count";
// 验证码key
String codeKey = "VerifyCode" + phone + ":code";
// 每个手机每天只能发送三次
String count = jedis.get(countKey);
if (count == null) {
// 为null的话就是第一次发送
jedis.setex(countKey,24*60*60,"1");
} else if (Integer.parseInt(count) <= 2) {
// 对key对应的value+1
jedis.incr(countKey);
} else if (Integer.parseInt(count) > 3) {
System.out.println("今天已经发送三次~");
jedis.close();
return;
}
// 看验证码是否为空
String codeK = jedis.get(codeKey);
jedis.setex(codeKey, 2*60,getCode());
jedis.close();
}
// 3、验证码验证
public static void getRedisCode(String phone,String code){
// 连接redis服务
Jedis jedis = new Jedis("192.168.8.134", 6379);
// 验证码key
String codeKey = "VerifyCode" + phone + ":code";
String redisCode = jedis.get(codeKey);
if (redisCode.equals(code)) {
System.out.println("success");
} else {
System.out.println("fail");
}
jedis.close();
}
}