这篇文章主要讲解了“Redis怎么实现验证码发送并限制每日发送次数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis怎么实现验证码发送并限制每日发送次数”吧!
输入手机号,点击发送后随机生成六位数字码,2分钟有效
输入验证码,点击验证,返回成功或失败
每个手机号每天只能输3次
每个手机每天只能输3次:incr每次发送之后+1,当值为3时提示不能发送,过期时间为当天结束
随机生成6位数字验证码:RandomUtil(hutool)
验证码2分钟有效:放入redis里并设置过期时间2分钟
判断验证码是否一致:从redis里获取验证码和输入的验证码进行比对
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; /** * 验证码控制器 * @author Ken-Chy129 * @date 2022/4/17 20:28 */ @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类 /** * 验证码 redis key */ public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; /** * 每日限制 redis key */ public static final String CAPTCHA_LIMIT_KEY = "captcha_limits:"; /** * 验证码有效期(分钟) */ public static final Integer CAPTCHA_EXPIRATION = 2;
感谢各位的阅读,以上就是“Redis怎么实现验证码发送并限制每日发送次数”的内容了,经过本文的学习后,相信大家对Redis怎么实现验证码发送并限制每日发送次数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。