当前位置: 首页>数据库>正文

若依集成短信验证码登陆功能思路加源码 RuoYi Redis暂存验证码

定义短信成员类

发送时间

手机号

验证码

接口一 (发送短信

1.发送短信前,先做手机号校验,结合自己项目中的发送短信平台的参数(签名、模板编码、失效时间、验证码长度、手机号)组成发送短信前的成员类

2.发送短信之前,做一些限制,比如同一IP10分钟内,只能发送三十条

   2.1.获取到请求体中的ip,通过这个key去redis查询 redisTemplate.opsForValue().get(countKey) == null

判断是否是第一次发送redisTemplate.opsForValue().set(countKey, "1", 10, TimeUnit.MINUTES);设置有效期为10分钟

     2.1.1.是第一次发送就添加redis中

     2.1.2.不是第一次发送Integer count = Integer.valueOf((String) redisTemplate.opsForValue().get(countKey));判断是否超过30次,超过就返回AjaxResult.error("频繁发送,请10分钟后重试");这里的十分钟并不是真正意义的十分钟内不超过三次,是时间间隔内(10分钟到30次*9分59秒)不能超过30次

3.发送验证码

  3.1.先将验证码存到redis中,redisTemplate.opsForValue().set(aliyunSms.getPhoneNumber(), code, 10, TimeUnit.MINUTES) 

   3.2.然后调用第三方平台发送验证码

接口二 (验证码校验)

  1. 通过手机号去redis中查询验证码String code = (String) redisTemplate.opsForValue().get(smsLogin.getPhoneNumber());
  2. 查完之后正确,就去mysql数据库里查询(个人信息包括角色权限)生成token令牌返回给前端

https://www.xamrdz.com/database/6bn1924654.html

相关文章: