[TOC]
### egg 发送短信逻辑 service
```
'use strict';
const Service = require('egg').Service;
class UserService extends Service {
/**
* 发送验证码
*/
async sendCode() {
//1. 获取用户手机号
const { phone } = this.ctx.request.body;
//2. 缓存中查询该手机号是否存在
const sendCodePhone = await this.service.cache.get(`sendCode_${phone}`);
if (sendCodePhone) this.ctx.errorHandle('您操作的太快了,验证码还未过期!', {}, 30001);
//3. 生成随机四位验证码
const randomCode = this.ctx.random();
// 调试环境 不请求阿里服务器
if (!this.config.aliSMS.isopen) {
await this._devCode(phone, randomCode);
}
//4. 请求阿里云API发送验证码
const ret = await this.service.alisms.sendSMS(phone, randomCode);
if (ret.Code === "OK") {
// 5.发送成功写入redis缓存 60 秒过期
this.service.cache.set(`sendCode_${phone}`, randomCode, this.config.aliSMS.expire);
// 6.写入消息队列
this.ctx.succHandle('发送验证码成功!');
}
}
// 模拟发送短信验证码
async _devCode(phone, randomCode) {
this.service.cache.set(`sendCode_${phone}`, randomCode, this.config.aliSMS.expire);
this.ctx.succHandle('请求验证码成功!', { randomCode }, 30002);
}
}
module.exports = UserService;
```
- 概述
- 起步
- 跨域配置
- 路径别名
- 路由
- api版本控制
- 错误和异常
- 全局异常处理
- 数据库
- 创建迁移文件
- sequelize数据类型
- 配置
- 新增
- 查询
- 条件查询
- 模糊查询
- 排序查询
- 聚合查询
- 分组查询
- 分页查询
- 修改
- 删除
- 获取器
- 修改器
- 静态属性
- 字段验证
- 外键约束
- 关联模型
- 一对一
- 一对多
- 左外连接
- 多对多
- 字段显示隐藏
- 事务
- 字段自增
- 验证层
- egg-validate
- indicative验证器
- egg-validate-plus
- betterValidate
- 校验规则
- 中间件
- 安全
- 数据加密
- 单向加密
- 示例代码
- 封装egg加密
- 上传
- path模块
- 单文件上传
- 多文件上传
- 按照日期存储
- 工具函数
- egg常用工具函数
- 缓存
- 配置缓存插件
- 设置缓存
- 获取缓存
- 删除缓存
- 消息队列
- rabbitMQ
- 安装
- 简单队列
- 工作队列
- 工作队列(dispach分发)
- 消息应答和持久化
- redis
- 数据类型
- 字符串类型(String)
- 哈希类型(Hash)
- 列表(List)
- 无序集合(Set)
- 可排序集合(Zset)
- 邮件系统
- nodeMailer
- 第三方模块
- 生成随机数
- JWT
- JWT鉴权
- 生成Token
- 短信服务
- 阿里大鱼短信验证码
- 发送短信逻辑
- 阿里短信Node类