目录1、功能2、分析3、实现1、功能 输入手机号,点击发送后随机生成六位数字码,2分钟有效输入验证码,点击验证,返回成功或失败每个手机号每天只能输3次 2、分析 每个手机每天只能输3
package cn.ken.blog.controller.common;
import cn.hutool.core.date.DateUnit;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.RandomUtil;
import cn.ken.blog.common.constant.Constants;
import cn.ken.blog.common.domain.Result;
import cn.ken.blog.common.enums.ErrorCodeEnum;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.util.ObjectUtils;
import org.springframework.WEB.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Date;
import java.util.concurrent.TimeUnit;
@RestController
@SuppressWarnings(value = { "unchecked", "rawtypes" })
public class CaptureController {
@Autowired
private RedisTemplate redisTemplate;
// 生成验证码
@GetMapping("getNumCode")
public Result<String> getNumCode(String phone) {
String captureLimiTKEy = Constants.CAPTCHA_LIMIT_KEY + phone;
Integer counts = (Integer) redisTemplate.opsForValue().get(captureLimitKey);
if (ObjectUtils.isEmpty(counts)) {
// 今天第一次验证,故之前缓存中无该键
// 距离今天结束剩下多少毫秒
long expire = DateUtil.endOfDay(new Date()).between(new Date(), DateUnit.MS);
redisTemplate.opsForValue().set(captureLimitKey, 1, expire, TimeUnit.MILLISECONDS);
} else if (counts < 3) {
// 没有超过限制次数
redisTemplate.opsForValue().increment(captureLimitKey);
} else {
// 超过限制次数,不生成验证码,直接返回
return new Result<String>().error(ErrorCodeEnum.OVER_LIMITS);
}
// 生成验证码
String code = RandomUtil.randomNumbers(6); // 随机生成六位数
String captureCodeKey = Constants.CAPTCHA_CODE_KEY + phone;
redisTemplate.opsForValue().set(captureCodeKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
return new Result<String>().success(captureCodeKey + ":" + code);
}
// 验证验证码
@GetMapping("verify")
public Result<String> verify(String phone, String code) {
String captureCodeKey = Constants.CAPTCHA_CODE_KEY + phone;
String realCode = (String) redisTemplate.opsForValue().get(captureCodeKey);
if (ObjectUtils.isEmpty(realCode)) {
// redis中不存在该用户生成的验证码,证明验证码以过期销毁
return new Result<String>().error(ErrorCodeEnum.OVERDUE_CODE);
}
if (realCode.equals(code)) {
return new Result<String>().success("验证成功");
} else {
return new Result<String>().error(ErrorCodeEnum.ERROR_CODE);
}
}
// @Scheduled(cron = "0 0 12 * * ?")
// private void clear() {
// redisTemplate.delete()
// }
}
// Constants类
public static final String CAPTCHA_CODE_KEY = "captcha_codes:";
public static final String CAPTCHA_LIMIT_KEY = "captcha_limits:";
public static final Integer CAPTCHA_EXPIRATION = 2;
到此这篇关于Redis实现验证码发送并限制每日发送次数的示例代码的文章就介绍到这了,更多相关Redis验证码发送并限制次数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Redis实现验证码发送并限制每日发送次数的示例代码
本文链接: https://www.lsjlt.com/news/146353.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0