API: MMS/MultiXSend - 彩信模板一对多发送
概览
MMS/multixsend
是 SUBMAIL 的彩信通知一对多(即1条API请求发送多个号码,并可以灵活控制每个联系人的文本变量)和群发 API 。
MMS/multixsend
提供完整且强大的彩信发送功能,MMS/multixsend
解决开发者在应用场景中的一对多或群发的需求,极大的提高 API 并发效率。
使用方法与 MMS/xsend
相似,不同的是 MMS/multixsend
去除了 to 和 vars 参数将其整合到 multi
参数中,可以将联系人的手机号码,和不同的文本变量整合,实现一对多场景中灵活控制文本变量的功能。
开发者们可在提交 MMS/multixsend
API 时,将 to
和 vars
参数编码为 JSON
字符串格式添加到 multi
参数中提交,multi
参数的数据模型请参考以下示例:
multi=[{
"to":"15*********",
"vars":{
"name":"kevin",
"code":123456
}
},{
"to":"18*********",
"vars":{
"name":"jacky",
"code":236554
}
},{
"to":"13*********",
"vars":{
"name":"tom",
"code":236554
}]
完整的 MMS/multixsend
POST 请求请参考以下示例:
appid=your_app_id
project=EM9sd
multi=[{
"to":"15*********",
"vars":{
"name":"kevin",
"code":123456
}
},{
"to":"18*********",
"vars":{
"name":"jacky",
"code":236554
}
},{
"to":"13*********",
"vars":{
"name":"tom",
"code":236554
}]
signature=your_app_key
URL
https://api-v4.mysubmail.com/mms/multixsend
支持格式
格式 | URL |
---|---|
json | https://api-v4.mysubmail.com/mms/multixsend.json (默认) |
xml | https://api-v4.mysubmail.com/mms/multixsend.xml |
yaml | https://api-v4.mysubmail.com/mms/multixsend.yaml |
http 请求方式
请求方式 | content-type设置 |
---|---|
http post | multipart/form-data 、x-www-form-urlencoded 、application/json |
是否需要授权
是
参阅 API 授权和验证机制
请求参数
参数 | 类型 | 必需/可选 | 默认 | 描述 |
---|---|---|---|---|
appid | string | 必需 | 无 | 在 SUBMAIL 应用集成中创建的彩信应用 ID |
project | string | 必需 | 无 | 模板标记(ID) |
multi | json string | 必需 | 无 | 收件人 to 联系人参数和 vars 文本变量的整合模式,请将 to 和 vars 整合成 json字符串格式提交(数据模型请参考本页概览页面提交打multi参数示例) |
tag | string | 可选 | 无 | 自定义标签功能,该标签可用作SUBHOOK追踪(32 个字符以内) |
timestamp | UNIX 时间戳 | 可选 | 无 | 参阅 API 授权与验证机制 > Timestamp UNIX 时间戳 |
sign_type | string | 可选 | normal | API 授权模式( md5 or sha1 or normal )参阅 API 授权与验证机制 > 授权和验证方式 |
sign_version | string | 可选 | 1 | signature加密计算方式(当sign_version传2时,multi参数不参与加密计算) |
signature | string | 必需 | 无 | 应用密匙或数字签名 参阅 API授权与验证机制 > 授权和验证方式 |
代码示例
发送一封测试短信
POST URL
https://api-v4.mysubmail.com/mms/multixsend.json
POST DATA
appid=your_app_id
&project=ThJBE4
&multi=[{
"to":"15*********",
"vars":{
"name":"kevin",
"code":123456
}
},{
"to":"18*********",
"vars":{
"name":"jacky",
"code":236554
}
}]
&signature=your_app_key
返回
[
{
"status": "success",
"to": "153xxxxxxx",
"send_id": "398164866e2e43b7569b09de7f091ca6",
"fee": 0.18
},
{
"status": "success",
"to": "191xxxxxxxx",
"send_id": "6ac3208ee91047286277e6251d97340b",
"fee": 0.18
}
]
返回值
请求成功
[
{
"status": "success",
"to": "153xxxxxxx",
"send_id": "398164866e2e43b7569b09de7f091ca6",
"fee": 0.18
},
{
"status": "success",
"to": "191xxxxxxxx",
"send_id": "6ac3208ee91047286277e6251d97340b",
"fee": 0.18
}
]
请求失败
[
{
"status": "success",
"to": "153xxxxxxxx",
"send_id": "4fc1bc42215a4ff167aaa3bea8cf5b75",
"fee": 0.18
},
{
"status": "error",
"code": 252,
"msg": "Incorrect recipient message address"
}
]
注:mms/multixsend API 中返回码将包含成功和失败的状态 ,API 在一条API中发起对多个号码的请求,所以返回状态也是按多条API计算的,例如:单次请求中包含3个联系人,其中2个联系人请求成功,1个联系人请求失败时,此时的API返回状态,将包含3条状态数组(即2条 status:success ,1条 status:error 的状态)
错误代码
参阅 API 错误代码