定义短信成员类
发送时间
手机号
接口一 (发送短信)
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.然后调用第三方平台发送验证码
接口二 (验证码校验)
- 通过手机号去redis中查询验证码String code = (String) redisTemplate.opsForValue().get(smsLogin.getPhoneNumber());
- 查完之后正确,就去mysql数据库里查询(个人信息包括角色权限)生成token令牌返回给前端