查询推送接口
推送的内容只能是 JSON 表示的一个推送对象。
调用验证
详情参见 REST API 概述的 鉴权方式 说明。
频率控制
详情参见推送限制策略的 接口限制 说明。
查询推送任务状态
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| workId | string | 是 | 推送任务的唯一任务id |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/push/getWorkStatus' \
--header 'key: 2e08782eb311b' \
--header 'sign: 15863cb512d9bac150cfc089cfac0b74' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","workId":"1609fr73wopsdgcqli4g"}'
响应示例
- 请求成功
{
"status": 200,
"res": "已下发",
"error": null,
"code": 2
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | string | 任务状态:"未开始"、“已下发”、“下发失败”、“推送完成”、“已取消”、“已撤回”、“任务异常” |
| code | number | 推送任务状态码: -1:未开始 -2:已下发 -3:下发失败 -4:推送完成 -5:已取消 -6:已撤回 -7:任务异常 |
| error | string | 报错信息(正常情况值为null) |
返回字段说明
未开始:创建定时任务,但是还未到任务执行时间
已下发:任务正常开始执行,还未到任务的截止时间
下发失败:任务开始执行异常,圈选人群过程失败
推送完成:到任务的截止时间,已处理下发完目标设备
已取消:成功取消执行该任务,不会继续下发
已撤回:成功撤回该任务
任务异常:未知异常
查询推送详情
根据workId查询
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| workId | string | 是 | 推送任务的唯一任务id |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/stats/getByWorkId' \
--header 'key: 2e08782eb311b' \
--header 'sign: 15863cb512d9bac150cfc089cfac0b74' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","workId":"1609fr73wopsdgcqli4g"}'
响应示例
- 请求成功
{
"status": 200,
"res": {
"workno": null,
"id": "1609fr73wopsdgcqli4g",
"android": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"ios": null,
"factory": null,
"mobpush": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"iostcp": null,
"androidtcp": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"apns": null,
"huawei": null,
"xiaomi": null,
"flyme": null,
"fcm": null,
"oppo": null,
"vivo": null,
"offlineIos": null,
"offlineAndroid": null,
"sms": null
},
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object | 返回结果 |
| res.ios | object | iOS的统计可以参考下面展开参数 |
| res.ios.fetchNum | number | 返回的设备数量 |
| res.ios.deliverNum | number | 实际下发的设备数量 |
| res.ios.deliverFailNum | number | 下发失败的数量 |
| res.ios.reportNum | number | 下发后回执的数量 (iOS回执不准确或者为0仅供参考) |
| res.ios.reportFailNum | number | 下发后回执失败的数量 |
| res.ios.clickNum | number | 点击通知的数量 |
| res.android | object | 安卓的统计可以参考上面iOS展开参数 |
| res.factory | object | 通过厂商和APNS下发的统计 参考同上 |
| res.mobpush | object | 通过MobPush通道下发的统计 参考同上 |
| res.iostcp | object | 通过MobPush通道下发iOS的统计 参考同上 |
| res.androidtcp | object | 通过MobPush通道下发Android的统计 参考同上 |
| res.apns | object | 通过APNS下发的统计 参考同上 |
| res.huawei | object | 通过华为厂商下发的统计 参考同上 |
| res.xiaomi | object | 通过小米厂商下发的统计 参考同上 |
| res.flyme | object | 通过魅族厂商下发的统计 参考同上 |
| res.fcm | object | 通过谷歌厂商下发的统计 参考同上 |
| res.oppo | object | 通过oppo厂商下发的统计 参考同上 |
| res.vivo | object | 通过vivo厂商下发的统计 参考同上 |
| res.sms | object | 短信补量下发统计 |
| res.offlineIos | object | iOS离线统计 |
| res.offlineAndroid | object | 安卓离线统计 |
| error | string | 错误信息 |
根据workId数组查询
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| workIds | string [] | 是 | 推送任务id的数组 |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/stats/getByWorkIds' \
--header 'key: 2e08782eb311b' \
--header 'sign: f5a56c1cd0c1613efe38659548aa930d' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","workIds":["1609fr73wopsdgcqli4g","1609hk2tuchfl5i3l1j4"]}'
响应示例
- 请求成功
{
"status": 200,
"res": [
{
"workno": null,
"id": "1609fr73wopsdgcqli4g",
"android": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"ios": null,
"factory": null,
"mobpush": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"iostcp": null,
"androidtcp": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"apns": null,
"huawei": null,
"xiaomi": null,
"flyme": null,
"fcm": null,
"oppo": null,
"vivo": null,
"offlineIos": null,
"offlineAndroid": null,
"sms": null
},
{
"workno": null,
"id": "1609hk2tuchfl5i3l1j4",
"android": {
"fetchNum": 2,
"deliverNum": 2,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"ios": null,
"factory": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 0,
"reportFailNum": 0,
"clickNum": 0
},
"mobpush": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"iostcp": null,
"androidtcp": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 1,
"reportFailNum": 0,
"clickNum": 0
},
"apns": null,
"huawei": {
"fetchNum": 1,
"deliverNum": 1,
"deliverFailNum": 0,
"reportNum": 0,
"reportFailNum": 0,
"clickNum": 0
},
"xiaomi": null,
"flyme": null,
"fcm": null,
"oppo": null,
"vivo": null,
"offlineIos": null,
"offlineAndroid": null,
"sms": null
}
],
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object | 返回结果 |
| res.ios | object | iOS的统计可以参考下面展开参数 |
| res.ios.fetchNum | number | 返回的设备数量 |
| res.ios.deliverNum | number | 实际下发的设备数量 |
| res.ios.deliverFailNum | number | 下发失败的数量 |
| res.ios.reportNum | number | 下发后回执的数量 (iOS回执不准确或者为0仅供参考) |
| res.ios.reportFailNum | number | 下发后回执失败的数量 |
| res.ios.clickNum | number | 点击通知的数量 |
| res.android | object | 安卓的统计可以参考上面iOS展开参数 |
| res.factory | object | 通过厂商和APNS下发的统计 参考同上 |
| res.mobpush | object | 通过MobPush通道下发的统计 参考同上 |
| res.iostcp | object | 通过MobPush通道下发iOS的统计 参考同上 |
| res.androidtcp | object | 通过MobPush通道下发Android的统计 参考同上 |
| res.apns | object | 通过APNS下发的统计 参考同上 |
| res.huawei | object | 通过华为厂商下发的统计 参考同上 |
| res.xiaomi | object | 通过小米厂商下发的统计 参考同上 |
| res.flyme | object | 通过魅族厂商下发的统计 参考同上 |
| res.fcm | object | 通过谷歌厂商下发的统计 参考同上 |
| res.oppo | object | 通过oppo厂商下发的统计 参考同上 |
| res.vivo | object | 通过vivo厂商下发的统计 参考同上 |
| res.sms | object | 短信补量下发统计 |
| res.offlineIos | object | iOS离线统计 |
| res.offlineAndroid | object | 安卓离线统计 |
| error | string | 错误信息 |
根据workno查询
workno为自定义任务ID,只能查询最近3天的数据
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| workno | string | 是 | 用户的推送任务id |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/stats/getByWorkno' \
--header 'key: 2e08782eb311b' \
--header 'sign: 8ecb4cf84760efe64578a83583b324b5' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","workno":"gxd123456789"}'
响应示例
- 请求成功
{
"status": 200,
"res": {
"workno": "gxd123456789",
"id": "1609hg9ho7l4a1hw8pog",
"android": {
"fetchNum": 2,
"deliverNum": 0,
"deliverFailNum": 0,
"reportNum": 0,
"reportFailNum": 0,
"clickNum": 0
},
"ios": null,
"factory": null,
"mobpush": null,
"iostcp": null,
"androidtcp": null,
"apns": null,
"huawei": null,
"xiaomi": null,
"flyme": null,
"fcm": null,
"oppo": null,
"vivo": null,
"offlineIos": null,
"offlineAndroid": null,
"sms": null
},
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object | 返回结果 |
| res.ios | object | iOS的统计可以参考下面展开参数 |
| res.ios.fetchNum | number | 返回的设备数量 |
| res.ios.deliverNum | number | 实际下发的设备数量 |
| res.ios.deliverFailNum | number | 下发失败的数量 |
| res.ios.reportNum | number | 下发后回执的数量 (iOS回执不准确或者为0仅供参考) |
| res.ios.reportFailNum | number | 下发后回执失败的数量 |
| res.ios.clickNum | number | 点击通知的数量 |
| res.android | object | 安卓的统计可以参考上面iOS展开参数 |
| res.factory | object | 通过厂商和APNS下发的统计 参考同上 |
| res.mobpush | object | 通过MobPush通道下发的统计 参考同上 |
| res.iostcp | object | 通过MobPush通道下发iOS的统计 参考同上 |
| res.androidtcp | object | 通过MobPush通道下发Android的统计 参考同上 |
| res.apns | object | 通过APNS下发的统计 参考同上 |
| res.huawei | object | 通过华为厂商下发的统计 参考同上 |
| res.xiaomi | object | 通过小米厂商下发的统计 参考同上 |
| res.flyme | object | 通过魅族厂商下发的统计 参考同上 |
| res.fcm | object | 通过谷歌厂商下发的统计 参考同上 |
| res.oppo | object | 通过oppo厂商下发的统计 参考同上 |
| res.vivo | object | 通过vivo厂商下发的统计 参考同上 |
| res.sms | object | 短信补量下发统计 |
| res.offlineIos | object | iOS离线统计 |
| res.offlineAndroid | object | 安卓离线统计 |
| error | string | 错误信息 |
根据日期查询
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 参数说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| day | string | 是 | 时间精确到小时yyyyMMdd 例如20200824 查询2020年08月24日 24号的所有推送 |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/stats/getByDay' \
--header 'key: 2e08782eb311b' \
--header 'sign: b223342835bbb272132e8a2732c75442' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","day":"20230518"}'
响应示例
- 请求成功
{
"status": 200,
"res": {
"appkey": "2e08782eb311b",
"day": "20230518",
"fetchNum": 5,
"fetchNumAndroid": 5,
"fetchNumIos": 0,
"workNum": 5,
"workNumAndroid": 5,
"workNumIos": 0,
"deliverNumTcp": 2,
"reportNumTcp": 2,
"clickNumTcp": 0,
"deliverNum": 3,
"deliverNumAndroid": 3,
"deliverNumIos": 0,
"reportNum": 2,
"reportNumAndroid": 2,
"reportNumIos": 0,
"clickNum": 0,
"clickNumAndroid": 0,
"clickNumIos": 0,
"apiNum": 0,
"apiNumAndroid": 0,
"apiNumIos": 0,
"activeNum": 2,
"activeNumAndroid": 2,
"activeNumIos": 0,
"newDeviceNum": 1,
"newDeviceNumAndroid": 1,
"newDeviceNumIos": 0,
"onlineTimeAvg": 0,
"onlineTimeAvgAndroid": 0,
"onlineTimeAvgIos": 0,
"onlineTimeAll": 0,
"onlineTimeAllAndroid": 0,
"onlineTimeAllIos": 0,
"openAppAvg": 7,
"openAppAvgAndroid": 7,
"openAppAvgIos": 0,
"openAppAll": 14,
"openAppAllAndroid": 14,
"openAppAllIos": 0
},
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object | 返回结果 |
| res.ios | object | iOS的统计可以参考下面展开参数 |
| res.ios.fetchNum | number | 返回的设备数量 |
| res.ios.deliverNum | number | 实际下发的设备数量 |
| res.ios.deliverFailNum | number | 下发失败的数量 |
| res.ios.reportNum | number | 下发后回执的数量 (iOS回执不准确或者为0仅供参考) |
| res.ios.reportFailNum | number | 下发后回执失败的数量 |
| res.ios.clickNum | number | 点击通知的数量 |
| res.android | object | 安卓的统计可以参考上面iOS展开参数 |
| res.factory | object | 通过厂商和APNS下发的统计 参考同上 |
| res.mobpush | object | 通过MobPush通道下发的统计 参考同上 |
| res.iostcp | object | 通过MobPush通道下发iOS的统计 参考同上 |
| res.androidtcp | object | 通过MobPush通道下发Android的统计 参考同上 |
| res.apns | object | 通过APNS下发的统计 参考同上 |
| res.huawei | object | 通过华为厂商下发的统计 参考同上 |
| res.xiaomi | object | 通过小米厂商下发的统计 参考同上 |
| res.flyme | object | 通过魅族厂商下发的统计 参考同上 |
| res.fcm | object | 通过谷歌厂商下发的统计 参考同上 |
| res.oppo | object | 通过oppo厂商下发的统计 参考同上 |
| res.vivo | object | 通过vivo厂商下发的统计 参考同上 |
| res.sms | object | 短信补量下发统计 |
| res.offlineIos | object | iOS离线统计 |
| res.offlineAndroid | object | 安卓离线统计 |
| error | string | 错误信息 |
查询每次下发的设备信息
该接口暂只支持查精准推送的推送设备详情(例如:别名、rid、别名文件推送和rid文件推送)
该接口维护中,暂不可用
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| workId | string | 是 | 推送的任务id |
| pageIndex | number | 是 | 页码 |
| pageSize | number | 是 | 页面条数 |
请求示例
curl --location --request POST 'http://api.push.mob.com/v3/stats/getByDevice' \
--header 'key: 2e08782eb311b' \
--header 'sign: f4050aef0ee25440d74119817aea42bf' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","workId":"1609fr73woqnm4lzptkw","pageIndex":1,"pageSize":20}'
响应示例
- 请求成功
{
"status": 200,
"res": {
"totalPages": 1,
"total": 1,
"content": [
{
"id": "1609fr73woqnm4lzptkw65l0soev0d0b4lc",
"rid": "65l0soev0d0b4lc",
"alias": null,
"guardId": "4ac763ec-522f-4969-9789-9b7c076116a5",
"tag": null,
"workId": "1609fr73woqnm4lzptkw",
"patchId": "1609fr73woqnm4lzptkw_0_XIAOMI",
"offline": null,
"deliver": [
"mobpush"
],
"deliverTime": [
1684736743029
],
"report": [
"mobpush"
],
"reportTime": [
1684736743321
],
"click": null,
"clickTime": null
}
]
},
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object | 返回结果 |
| res.totalPages | number | 返回总的页数 |
| res.total | number | 返回设备的总数 |
| res.content | object [] | 返回的下发设备信息数组 |
| res.content.rid | string | 设备的绑定id 可以在客户端打印获取 |
| res.content.workId | string | 任务id |
| res.content.alias | string | 设备别名 |
| res.content.tag | string | 标签 |
| res.content.id | string | 设备id |
| res.content.patchId | string | 推送批次id(暂时是MobTech内部自己使用的字段) |
| res.content.deliver | string [] | 下发类型如["apns"] |
| res.content.deliverTime | number | 下发次数 |
| res.content.report | string [] | 下发回执类型 |
| res.content.reportTime | number | 回执次数 |
| res.content.click | string [] | 点击类型 |
| res.content.clickTime | number | 点击次数 |
| error | string | 错误信息 |
根据活动任务id查询活动任务聚合数据
调用地址
推送对象
- 以 JSON 格式表达,表示一条推送相关的所有信息
| 参数 | 类型 | 必须 | 说明 |
|---|---|---|---|
| appkey | string | 是 | Mob后台的MobAppKey |
| activityWorkId | string | 是 | 推送的活动任务id |
请求示例
// 活动任务id为用户自行设置,且唯一
curl --location --request POST 'http://api.push.mob.com/v3/stats/getActivity' \
--header 'key: 2e08782eb311b' \
--header 'sign: 03ee692eb1319994970167619cb6f721' \
--header 'Content-Type: application/json' \
--data-raw '{"appkey":"2e08782eb311b","activityWorkId":"1775565980385"}'
响应示例
- 请求成功
{
"status": 200,
"res": {
"appkey": "2e08782eb311b",
"activityWorkId": "1775565980385",
"fetchNum": 2,
"deliverNum": 0,
"reportNum": 0,
"clickNum": 0
},
"error": null
}
- 请求失败
{
"status": 5801,
"res": null,
"error": "数据校验失败"
}
- 响应参数
| 参数 | 类型 | 说明 |
|---|---|---|
| status | number | 状态码 |
| res | object [] | 返回结果 |
| res.appkey | string | Mob的appkey |
| res.activityWorkId | string | 活动任务id |
| res.fetchNum | number | 目标数 |
| res.deliverNum | number | 下发数 |
| res.reportNum | number | 到达数 |
| res.clickNum | number | 点击数 |
| error | string | 错误信息 |