휴대폰 번호를 입력하고 보내기를 클릭하면 2분 동안 유효한 6자리 코드가 무작위로 생성됩니다.
인증 코드를 입력하고 확인을 클릭하면 성공 또는 실패를 반환합니다
각각 휴대폰 번호는 매일 사용할 수 있습니다. 3번 분실 가능
각 휴대폰은 하루에 3번만 분실될 수 있습니다. 각 전송 후 값이 3일 때마다 +1이 증가합니다. 보낼 수 없다는 메시지가 뜨고 유효기간은 하루가 다 됩니다
무작위로 6자리 인증코드 생성: RandomUtil (hutool)
인증코드는 2분 동안 유효합니다: 넣어주세요 redis에서 만료 시간을 2분으로 설정
인증 코드가 일치하는지 판단: 인증 코드를 받아 입력한 인증 코드를 비교
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는 인증 코드 전송을 어떻게 구현하고 일일 전송 횟수를 제한합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!