Redis_Jedis 实践
文章目录
1、完成一个手机验证码功能
要求:
- 输入手机号,点击发送后随机生成 6 位数字码,2 分钟有效;
- 输入验证码,点击验证,返回成功或失败;
- 每个手机号每天只能输入 3 次。
2、技术点
- 生成随机 6 位数字验证码 ==> Random
- 验证码在 2 分钟内有效 ==> 把验证码放到 redis 里边,设置过期时间 120 秒
- 判断验证码是否一致 ==> 从 redis 获取验证码和输入的验证码进行比较
- 每个手机每天只能发送 3 次验证码 ==> incr 每次发送之后 +1;大于 2 的时候,提示不能发送
3、代码实现
//1、生成一个6位的数字验证码
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、每个手机每天只能发3次,验证码放到redis中,设置过期日期
public static void vertifyCode(String phone){
//创建一个Jedis对象
Jedis jedis = new Jedis("192.168.196.128", 6379);
//拼接key
//手机发送次数key
String countKey = "VertifyCode" + phone + ":count";
//验证码key
String codeKey = "VertifyCode" + phone + ":code";
//每个手机每天只能发送三次
String count = jedis.get(countKey);
if (count == null){
//没有发送次数,第一次发送
//设置发送次数是1
jedis.setex(countKey, 24*60*60, "1");
} else if (Integer.parseInt(count) <= 2){
//发送次数+1
jedis.incr(countKey);
} else if (Integer.parseInt(count) > 2){
//发送3次,不能再进行发送
System.out.println("今天的发送次数已经超过三次");
jedis.close();
return;
}
//发送的验证码放到redis里边
String vcode = getCode();
jedis.setex(codeKey, 120, vcode);
jedis.close();
}
//3、验证码校验
public static void getRedisCode(String phone, String code){
//先从redis中获取验证码
Jedis jedis = new Jedis("192.168.196.128", 6379);
//验证码key
String codeKey = "VertifyCode" + phone + ":code";
String redisCode = jedis.get(codeKey);
//判断
if (redisCode.equals(code)){
System.out.println("成功");
} else {
System.out.println("失败");
}
}
public static void main(String[] args) {
//模拟验证码的发送
//vertifyCode("17809298555");
getRedisCode("17809298555", "4444");
}