send-sms.md 7.4 KB
Newer Older
W
wanganxp 已提交
1
**短信发送**
雪洛's avatar
雪洛 已提交
2

W
wanganxp 已提交
3
从HBuilderX 2.8.1起,uniCloud内置了短信发送API。给开发者提供更方便、更便宜的短信发送能力。
W
wanganxp 已提交
4

W
wanganxp 已提交
5
该服务类似小程序的模板消息,在一个固定模板格式的文字里自定义某些字段,而不是所有文字都可以随便写。
W
wanganxp 已提交
6

W
wanganxp 已提交
7
后续视需求提供自定义短信模板功能。
W
wanganxp 已提交
8 9 10 11 12 13

使用本功能需要在[DCloud开发者中心](https://dev.dcloud.net.cn/uniSms)开通并充值,教程参考[短信服务开通指南](https://ask.dcloud.net.cn/article/37534)

因涉及费用,为保障安全,本能力应该在云函数中调用,而不是在前端调用。

云函数API名称:`uniCloud.sendSms`
雪洛's avatar
雪洛 已提交
14 15 16

**参数说明**

W
wanganxp 已提交
17 18 19 20 21 22
参数结构体为json格式。

|参数名		|类型	|必填	|说明															|
|:-:		|:-:	|:-:	|:-:															|
|smsKey		|String	|是		|调用短信接口的密钥key,从 dev.dcloud.net.cn/uniSms 后台获取		|
|smsSecret	|String	|是		|调用短信接口的密钥secret,从 dev.dcloud.net.cn/uniSms 后台获取	|
W
wanganxp 已提交
23
|phone		|String	|是		|发送目标手机号,暂仅支持中国大陆手机号,不能填写多个手机号|
W
wanganxp 已提交
24 25
|templateId	|String	|是		|模版Id,短信内容为固定模板,详见下方说明						|
|data		|Object	|是		|模版里的各个字段,json格式										|
雪洛's avatar
雪洛 已提交
26

雪洛's avatar
雪洛 已提交
27
**参数templateId说明**
雪洛's avatar
雪洛 已提交
28

W
wanganxp 已提交
29
目前短信功能包括如下模版,暂不可扩展新模版,模版形式如下。参数data内的字段会填充到模版内容里。
雪洛's avatar
雪洛 已提交
30

W
wanganxp 已提交
31 32 33 34
|模版Id				|模板内容																							|
|:-:				|:-:																								|
|`uniID_code`		|【uniID】“${name}”验证码:${code},用于${action},${expMinute}分钟内有效,请勿泄露并尽快验证。	|
|`uni_verify_code`	|【uni验证】“${name}”验证码:${code},用于${action},${expMinute}分钟内有效,请勿泄露并尽快验证。	|
雪洛's avatar
雪洛 已提交
35 36 37
|`uni_order_unpaid` |【uni订单通知】您在“${name}”的订单${orderNo}未支付,将在${minute}分钟后自动关闭,请及时完成订单|
|`uni_booking` |【uni预约通知】您已成功预订“${name}”提供的${service}。预约时间${dateTime}。注意事项:${notice}|
|`uni_order_shipped` |【uni订单通知】您在“${name}”的订单${orderNo}已发货,${expressCompany}单号${expressNo},请注意签收|
W
wanganxp 已提交
38

W
wanganxp 已提交
39 40 41
`uniID_code`模板为uni-ID业务专用。如使用uniCloud的uni-id账户服务,无需自行开发代码调用本API,直接用uni-id即可,内置了注册和忘记密码的短信验证码服务。[详见](https://uniapp.dcloud.io/uniCloud/uni-id)

`uni_verify_code`模板为开发者自定义使用,如未使用uni-id,则可以使用本模板发送短信验证码,也可以在支付等需要再次验证身份的场景中使用。
W
wanganxp 已提交
42

雪洛's avatar
雪洛 已提交
43 44
本地运行云函数时,需要`2.8.5+`版本的HBuilderX才可以使用`uni_order_unpaid``uni_booking``uni_order_shipped`三个模板,上传并运行不受HBuilderX版本影响。

W
wanganxp 已提交
45
每个短信模板的商用均必须在运营商备案。上述模板之所以带有uni前缀,是因为它们是DCloud已经在运营商备案过的模板,这些模板开发者可以直接使用。
W
wanganxp 已提交
46

W
wanganxp 已提交
47
开发者若需自定义短信模板(包括去掉前面的uni前缀),则需要人工处理,再次向运营商备案。如有相关需求的开发者,可以发送申请邮件到service@dcloud.io,说明账户、预计发送量和新模板格式。由于涉及人工,充值额低于1百元的开发者的申请暂时不会被处理。
W
wanganxp 已提交
48

W
wanganxp 已提交
49
模板中`${}`中的内容为自定义字段,在data中填写每个自定义字段后拼接成完整的短信内容。
雪洛's avatar
雪洛 已提交
50

雪洛's avatar
雪洛 已提交
51
**上述模版对应的data内参数限制如下**
雪洛's avatar
雪洛 已提交
52

雪洛's avatar
雪洛 已提交
53
所有参数中均不可包含`【``】`
W
wanganxp 已提交
54

雪洛's avatar
雪洛 已提交
55 56 57 58 59 60 61 62 63 64 65 66 67
|参数名					|类型		|长度限制		|说明																																									|
|:-:						|:-:		|:-:				|:-:																																									|
|name						|String	|长度最大15	|应用名称																																							|
|code						|String	|长度最大6	|验证码串,注意一般需要自行提供随机数并在数据库中存储以方便校验,只允许使用字母或数字	|
|action					|String	|长度最大6	|验证码用途																																						|
|expMinute			|String	|长度最大2	|验证码过期时间,单位分钟,即不超过99分钟。过期校验逻辑需自行开发											|
|orderNo				|String	|长度最大20	|订单号																																								|
|minute					|String	|长度最大2	|单位分钟,即不超过99分钟。																														|
|service				|String	|长度最大10	|-																																										|
|dateTime				|String	|长度最大18	|-																																										|
|notice					|String	|长度最大20	|-																																										|
|expressCompany	|String	|长度最大12	|-																																										|
|expressNo			|String	|长度最大20	|-																																										|
雪洛's avatar
雪洛 已提交
68 69 70

**返回值**

W
wanganxp 已提交
71 72 73
接口调用失败时会直接抛出错误,调用成功时才会有返回值。

注意接口调用成功不代表短信发送成功,比如目标手机关机会导致短信发送失败。真实的短信发送成功与否请在[https://dev.dcloud.net.cn/uniSms](https://dev.dcloud.net.cn/uniSms)后台查看报表。
雪洛's avatar
雪洛 已提交
74

W
wanganxp 已提交
75 76
|参数名	|类型	|说明			|
|:-:	|:-:	|:-:			|
雪洛's avatar
雪洛 已提交
77 78 79 80 81 82 83 84 85 86
|errCode|Number|成功返回0,调用失败错误码见下表	|
|errMsg|String|错误描述,调用失败时返回	|

**错误码说明**

|错误码	|错误																	|
|:-:		|:-:																	|
|10001	|参数校验未通过,errMsg内会给出详细信息|
|10002	|校验未通过,errMsg内会给出详细信息		|
|10003	|其他错误															|
雪洛's avatar
雪洛 已提交
87 88 89 90

**调用示例**

```js
雪洛's avatar
雪洛 已提交
91 92
'use strict';
exports.main = async (event, context) => {
雪洛's avatar
雪洛 已提交
93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
  try {
    const res = await uniCloud.sendSms({
      smsKey: '****************',
      smsSecret: '****************',
      phone: '188********',
      templateId: 'uniID_code',
      data: {
        name: 'DCloud',
        code: '123456',
        action: '注册',
        expMinute: '3',
      }
    })
    // 调用成功,请注意这时不代表发送成功
    return res
  } catch(err) {
    // 调用失败
雪洛's avatar
雪洛 已提交
110 111
    console.log(err.errCode)
    console.log(err.errMsg)
雪洛's avatar
雪洛 已提交
112
    return {
雪洛's avatar
雪洛 已提交
113 114
      code: err.errCode
      msg: err.errMsg
雪洛's avatar
雪洛 已提交
115 116
    }
  }
雪洛's avatar
雪洛 已提交
117
};
雪洛's avatar
雪洛 已提交
118

雪洛's avatar
雪洛 已提交
119 120
```

W
wanganxp 已提交
121 122 123 124 125
本示例发送的短信,在手机上将显示为:
```
【uniID】“DCloud”验证码:123456,用于注册,3分钟内有效,请勿泄露并尽快验证。
```

雪洛's avatar
雪洛 已提交
126 127
**注意事项**

hbcui1984's avatar
hbcui1984 已提交
128 129
- data内如果有`测试``test`等字样,系统可能会被判定为测试用途,不会真正把短信下发到对应手机(此行为由运营商控制,可能真实发送,也可能不发送)
-[DCloud开发者中心](https://dev.dcloud.net.cn/uniSms)绑定`uniCloud`服务空间后,将会只允许绑定的服务空间调用此接口,绑定列表为空时表示不限制服务空间
雪洛's avatar
雪洛 已提交
130
- 短信内容不可包含★、 ※、 →、 ●等特殊符号,可能会导致短信乱码
W
wanganxp 已提交
131 132
- 如果是用于用户注册的短信验证码,那么强烈推荐使用uni-id,这是一套云端一体的、完善的用户管理方案,已经内置封装好的短信验证码功能,详见:[https://ext.dcloud.net.cn/plugin?id=2116](https://ext.dcloud.net.cn/plugin?id=2116)
- Android手机在App端获取短信验证码,参考:[https://ask.dcloud.net.cn/article/676](https://ask.dcloud.net.cn/article/676)
雪洛's avatar
雪洛 已提交
133
- 短信内容超过70个字符时为长短信,需分条发送,每67个字按一条短信计算