使用场景
接入该接口请先完成接入准备
批量邮件发送,此接口适用【相同内容不同邮箱】的批量发送数据请求记录生命周期:1周
备注:邮件发送需要完成发件人和发件域的设置,另外需要保持账户充足的余额
请求url
https://sending.mambasms.com/open/api/international/email/batch/send
请求方式
POST
公共参数说明
请求头 | 字段类型 | 是否必填 | 限制 | 值 |
---|---|---|---|---|
X-Mamba-Access-Token | String | Y | 接入准备过程中获取的秘钥 | |
Content-Type | String | Y | application/json |
请求参数说明
参数 | 类型 | 必填 | 限制 | 描述 | 示例值 |
---|---|---|---|---|---|
request_id | String | Y | 最长64个字符 | 请求业务ID,相同值只处理一次 | 7875160946299813889 |
campaign_id | String | Y | 最长64个字符 | 活动id | |
campaign_name | String | N | 最长200个字符 | 活动名称 | |
from_name | String | N | 最长100个字符 | 发件人名称 | |
from | String | Y | 发件人,需要后台配置生效的;另外对应的发件域需要后台验证通过 | 发件人邮箱 | |
subject | String | Y | 最长500个字符 UTF-8不含RFC2047 | 邮件主题 | |
content | String | Y | html 、text 其中html不能含meta标签(自动清除meta标签) | 发送邮件内容 | |
list_remark | String | N | 最长500个字符 | 收件人分组说明 | |
emails | String | Y | 多个英文逗号分隔,最多1000 | 邮箱,多个邮箱英文逗号分隔,单批次不允许重复邮箱,为保障邮件发送成功率,避免特殊字符造成发送失败 | |
total | Long | Y | emails的个数,不一致时则会报错 | ||
reply_to | String | Y | 组装 email's "Reply-To" header. | ||
request_time | String | N | ISO-8601时间格式 | 请求时间 | 示例值:2023-10-27T15:18:42.223+08:00 |
biz_param | JSON | N | 限制256个字符 | 自定义业务请求参数,回调时携带,JSON格式 | |
open_tracking | boolean | N | true/false | 是否开启邮件打开追踪事件默认true | |
click_tracking | boolean | N | true/false | 是否开启邮件连接点击追踪事件默认true | |
headers | object | N | key/value 键值对 | 邮件头 | { "X-Customer-Campaign-ID": "christmas_campaign" } |
幂等机制:request_id,若失败检查失败原因。
发件人与发件域说明:发件人“@”之后的部分为发件域,配置发件域时请保持一致,发件域配置时会进行验证,发件人域必须使用认证后的发件域
若遇到请求失败,非邮件格式等错误情况,再次尝试(使用新的requestId,否则会幂等结果),部分失败原因存在请求速率过快导致。
请求参数示例
{
"request_id": "7874213545233465350",
"campaign_id":"1891498156651418748",
"campaign_name":"Campaign name",
"from": "[email protected]",
"subject": "winner gift",
"content": "thanks for your join,you will get a gift",
"emails": "[email protected],[email protected]",
"total": 1,
"reply_to": "[email protected]",
}
设置退订连接
Mamba系统提供退订连接变量 user_defined_unsubscribe_link 使用方式如下
<a href="{{{user_defined_unsubscribe_link}}}">unsubscribe</a>
响应参数说明
参数 | 类型 | 是否必填 | 限制 | 描述 | 示例值 |
---|---|---|---|---|---|
status | String | Y | 最多20个字符 | 批次状态码 all_success--全部成功 part_success--部分成功 fail--失败 | all_success |
batch_id | String | Y | 最多64个字符 | 批次id | 8064284299267792899 |
message | String | Y | 最多128个字符 | status的描述 | 提交成功 |
batch_iso_time | String | Y | ISO-8601 | 响应时间 | 2023-10-27T15:18:42.223+08:00 |
total_accepted_recipients | Integer | Y | 总接收数, 当status=all_success时,与请求参数emails的个数一致; 当status=part_success时为成功的数量 当status=fail时,为0 | 2 | |
total_rejected_recipients | Integer | Y | 总拒绝数, 当status=all_success时,为0; 当status=part_success时为失败的数量 当status=fail时,与请求参数emails的个数一致 | 2 | |
rcpt_to_errors | String | N | 对status=part_success时的错误数据描述信息 | [{"message":"invalid recipients[2] address.email: zhangweimambasms.com","code":"1300"},{"message":"invalid recipients[3] address.email: zhangwesmambasms.com","code":"1300"}] |
响应参数示例
请求失败
{
"status": "fail",
"batchId": "8147366765119299585",
"message": "batch request exception",
"batchIsoTime": "2023-11-24T10:33:58.163+08:00",
"total_accepted_recipients": 0,
"total_rejected_recipients": 1,
"rcpt_to_errors": null
}
全部成功
{
"status": "all_success",
"batchId": "8147529114883244033",
"message": "all_success",
"batchIsoTime": "2023-11-24T11:52:14.348+08:00",
"total_accepted_recipients": 1,
"total_rejected_recipients": 0,
"rcpt_to_errors": null
}
部分成功
部分错误请求参数示例,例如邮件格式错误的数据
{
"request_id": "7874213545233465350",
"from": "[email protected]",
"subject": "winner gift",
"content": "thanks for your join,you will get a gift",
"emails": "[email protected],zhangweimambasms.com",
"total": 2,
"reply_to": "[email protected]",
"request_time": "11144441111",
"biz_param": "oookk"
}
响应结果
{
"status": "part_success",
"batchId": "8147529114883244037",
"message": "part_success",
"batchIsoTime": "2023-11-24T11:58:02.418+08:00",
"total_accepted_recipients": 1,
"total_rejected_recipients": 1,
"rcpt_to_errors": "[{\"code\":\"1300\",\"message\":\"invalid recipients[1] address.email: zhangweimambasms.com\"}]"
}