Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-unicloud-zh
提交
7403e539
U
unidocs-unicloud-zh
项目概览
DCloud
/
unidocs-unicloud-zh
通知
83
Star
2
Fork
19
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
8
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-unicloud-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
8
合并请求
8
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
7403e539
编写于
10月 24, 2024
作者:
DCloud_JSON
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update docs/uni-cloud-push
上级
73e21368
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
91 addition
and
69 deletion
+91
-69
docs/uni-cloud-push/api.md
docs/uni-cloud-push/api.md
+30
-50
docs/uni-cloud-push/options.md
docs/uni-cloud-push/options.md
+61
-19
未找到文件。
docs/uni-cloud-push/api.md
浏览文件 @
7403e539
...
...
@@ -64,30 +64,31 @@
await
uniPush
.
sendMessage
(
OBJECT
)
```
#### 入参说明
|名称|类型|必填|默认值|描述|平台特性|
|--|--|--|--|--|--|
|user_id|String、Array|否|无|基于uni-id的_id,指定接收消息的用户id。
</br>
支持多个以数组的形式指定多个用户id,如["user_id-1","user_id-2"],数组长度不大于500| |
|user_tag|String、Array|否|无|指定接收消息的用户标签,基于uni-id账户体系。
</br>
支持多个以数组的形式指定多个标签,如["user_tag-1","user_tag-2"],数组长度不大于500| |
|device_id|String、Array|否|无|指定接收消息的设备id,基于opendb表的device设备(未开通uni统计或基于uni-id-pages开发的应用,必须基于uni-id-co登录后才可使用)| |
|push_clientid|String、Array|否|无|基于
[
uni.getPushClientId
](
https://uniapp.dcloud.net.cn/api/plugins/push
)
获取的客户端推送标识,指定接收消息的设备。
</br>
支持多个以数组的形式指定多个设备,如["cid-1","cid-2"],数组长度不大于1000| |
|getui_custom_tag|String|否|无|基于个推
`getui_custom_tag`
,指定接收消息接设备;
</br>
注:该功能需要申请相关套餐,请点击右侧“技术咨询”了解详情 。| |
|getui_big_data_tag|Object Array|否|无|对指定应用的符合筛选条件的设备群发推送消息。支持定时、定速功能。详见下方
[
getui-big-data-tag 说明
](
#getui-big-data-tag
)
| |
|getui_alias|String、Array|否|无|个推自定义客户端别名,指定消息接收者。
</br>
支持多个以数组的形式指定多个设备,如["getui_alias-1","getui_alias-2"],数组长度不大于1000| |
|platform|String、Array|否|"ALL"|指定接收消息的平台,"ALL"表示所有平台。
</br>
支持用数组枚举支持的平台,如:
[
"web","app-ios","app-android","mp-weixin"],详情见下方[platform 说明
](
#platform-说明
)
</br>
仅通过
`user_id`
、
`user_tag`
指定消息接收者时有效|
|check_token|Boolean|否|true|校验客户端登陆状态是否有效(含token过期)
</br>
仅通过
`user_id`
、
`user_tag`
指定消息接收者时有效| |
|title|String|是|无|通知栏标题,长度小于20|APP|
|content|String|是|无|通知栏内容,长度小于50|APP|
|payload|String、Object|是|无|推送透传数据,app程序接受的数据,长度小于800字符;
</br>
注意:为了确保离线厂商通道,可以获得payload的值,请用Object格式如:
`{"text":"xxx"}`
| |
|force_notification|Boolean|否|false|无论是离线推送还是在线推送,都自创建通知栏消息。HBuilderX 3.5.2 及其以上版本的客户端支持| App|
|badge|Number、String|否|+1|设置应用右上角数字,用于提醒用户未阅读消息数量,支持在原有数字上的+、-操作;
</br>
例如:badge=+1,表示当前角标+1;
</br>
badge=-1,(仅iOS支持)表示当前角标-1(角标>=0);
</br>
badge=1,(仅iOS和华为EMUI版本10.0.0+支持)表示当前角标置成1。| ios、android-华为|
|channel|Object|否|无|消息渠道设置,避免被限量推送、静默推送(静音且需下拉系统通知栏才可见通知内容),需要在各家发邮件申请,详情下方
[
channel说明
](
#channel
)
</br>
此功能依赖uni原生插件
[
点此打开
](
https://ext.dcloud.net.cn/plugin?id=7482
)
打包后生效。| android|
|request_id|String|否|无|请求唯一标识号,10-32位之间;如果
`request_id`
重复,会导致消息丢失||
|group_name|String|否|无|任务组名。多个消息任务可以用同一个任务组名,后续可根据任务组名查询推送情况(长度限制100字符,且不能含有特殊符号);
</br>
仅基于user_id、push_clientid、getui_custom_tag指定消息接收者,或对应用的所有用户群发推送消息时有效。||
|sound|String|否|无|消息提醒铃声设置,常见的离线语音播报功能就是用它实现。android需要设置channel生效,详见下方
[
铃声设置注意
](
#sound
)
</br>
如果铃声文件未找到,响铃为系统默认铃声。
</br>
铃声文件需要使用uni原生插件
[
点此打开
](
https://ext.dcloud.net.cn/plugin?id=7482
)
打包后生效。
</br>
建议iOS和Android铃声使用一致的文件名称。直接填写文件名,不含扩展名;如:pushsound.caf或pushsound.mp3,直接填写pushsound即可。|
|content_available|Number|否|0|0表示普通通知消息(默认为0);
</br>
1表示静默推送(无通知栏消息),静默推送时不需要填写其他参数。
</br>
苹果官方建议1小时最多推送3条静默消息|ios |
|open_url|string|否|无|填写该值将:强制push类型为“通知栏消息”,点击后系统浏览器将打开此链接。以
`http(s)://`
开头的有效可访问链接,华为通道必须使用https。长度小于300|android|
|settings|Object|否|无|推送条件设置,详细解释见下方settings说明||
|options|Object|否|无|其他配置,
[
更多关于options的说明
](
../uni-cloud-push/options
)
||
|名称 |类型 |必填 |默认值 |描述 |平台特性 |
|-- |-- |-- |-- |-- |-- |
|user_id |String、Array |否 |无 |基于uni-id的_id,指定接收消息的用户id。
</br>
支持多个以数组的形式指定多个用户id,如["user_id-1","user_id-2"],数组长度不大于500 | |
|user_tag |String、Array |否 |无 |指定接收消息的用户标签,基于uni-id账户体系。
</br>
支持多个以数组的形式指定多个标签,如["user_tag-1","user_tag-2"],数组长度不大于500 | |
|device_id |String、Array |否 |无 |指定接收消息的设备id,基于opendb表的device设备(未开通uni统计或基于uni-id-pages开发的应用,必须基于uni-id-co登录后才可使用) | |
|push_clientid |String、Array |否 |无 |基于
[
uni.getPushClientId
](
https://uniapp.dcloud.net.cn/api/plugins/push
)
获取的客户端推送标识,指定接收消息的设备。
</br>
支持多个以数组的形式指定多个设备,如["cid-1","cid-2"],数组长度不大于1000 | |
|getui_custom_tag |String |否 |无 |基于个推
`getui_custom_tag`
,指定接收消息接设备;
</br>
注:该功能需要申请相关套餐,请点击右侧“技术咨询”了解详情 。 | |
|getui_big_data_tag |Object Array |否 |无 |对指定应用的符合筛选条件的设备群发推送消息。支持定时、定速功能。详见下方
[
getui-big-data-tag 说明
](
#getui-big-data-tag
)
| |
|getui_alias |String、Array |否 |无 |个推自定义客户端别名,指定消息接收者。
</br>
支持多个以数组的形式指定多个设备,如["getui_alias-1","getui_alias-2"],数组长度不大于1000 | |
|platform |String、Array |否 |"ALL" |指定接收消息的平台,"ALL"表示所有平台。
</br>
支持用数组枚举支持的平台,如:
[
"web","app-ios","app-android","mp-weixin"],详情见下方[platform 说明
](
#platform-说明
)
</br>
仅通过
`user_id`
、
`user_tag`
指定消息接收者时有效 |
|check_token |Boolean |否 |true |校验客户端登陆状态是否有效(含token过期)
</br>
仅通过
`user_id`
、
`user_tag`
指定消息接收者时有效 | |
|title |String |是 |无 |通知栏标题,长度小于20 |APP |
|content |String |是 |无 |通知栏内容,长度小于50 |APP |
|payload |String、Object |是 |无 |推送透传数据,app程序接受的数据,长度小于800字符;
</br>
注意:为了确保离线厂商通道,可以获得payload的值,请用Object格式如:
`{"text":"xxx"}`
| |
|category |Object |否 |无 |消息类别,鸿蒙通道为必填项,其他通道若未进行配置,会被认定为营销类别,从而受到限量推送。
</br>
当前仅有鸿蒙、华为以及 vivo 厂商支持此项配置。
</br>
例如:{"harmony":"EXPRESS", "huawei":"EXPRESS", "vivo":"ORDER"}。
</br>
其中,harmony 与 huawei 的取值相同
[
详情查看
](
https://developer.huawei.com/consumer/cn/doc/HMSCore-Guides/message-classification-0000001149358835#section1085395991513
)
</br>
vivo 的取值
[
详情查看
](
https://dev.vivo.com.cn/documentCenter/doc/359#s-o2cg9ph0
)
|Android、harmony 注意:仅HBuilderX4.31及其以上版本支持|
|force_notification |Boolean |否 |false |无论是离线推送还是在线推送,都自创建通知栏消息。HBuilderX 3.5.2 及其以上版本的客户端支持 |ios、android |
|badge |Number、String |否 |+1 |设置应用右上角数字,用于提醒用户未阅读消息数量,支持在原有数字上的+、-操作;
</br>
例如:badge=+1,表示当前角标+1;
</br>
badge=-1,(仅iOS支持)表示当前角标-1(角标>=0);
</br>
badge=1,(仅iOS和华为EMUI版本10.0.0+支持)表示当前角标置成1。 |ios、android-华为 |
|channel |Object |否 |无 |已不推荐使用,请通过category和
[
options
](
../uni-cloud-push/options
)
配置。 |android |
|request_id |String |否 |无 |请求唯一标识号,10-32位之间;如果
`request_id`
重复,会导致消息丢失 | |
|group_name |String |否 |无 |任务组名。多个消息任务可以用同一个任务组名,后续可根据任务组名查询推送情况(长度限制100字符,且不能含有特殊符号);
</br>
仅基于user_id、push_clientid、getui_custom_tag指定消息接收者,或对应用的所有用户群发推送消息时有效。 | |
|sound |String |否 |无 |消息提醒铃声设置,常见的离线语音播报功能就是用它实现。详见下方
[
实现推送铃声
](
#sound
)
|
|content_available |Number |否 |0 |0表示普通通知消息(默认为0);
</br>
1表示静默推送(无通知栏消息),静默推送时不需要填写其他参数。
</br>
苹果官方建议1小时最多推送3条静默消息 |ios |
|open_url |string |否 |无 |填写该值将:强制push类型为“通知栏消息”,点击后系统浏览器将打开此链接。以
`http(s)://`
开头的有效可访问链接,华为通道必须使用https。长度小于300 |android |
|settings |Object |否 |无 |推送条件设置,详细解释见下方settings说明 | |
|options |Object |否 |无 |实现部分厂商特定功能,包括仅部分厂商支持、不常用或厂商临时新增的功能(不依赖 uni-push,厂商文档支持的参数可直接使用)。例如:推送渠道 ID、消息分类(部分厂商未配置时可能被限量推送或静默推送,即静音且需下拉系统通知栏才可见通知内容)、通知栏富文本
[
更多关于options的说明
](
../uni-cloud-push/options
)
| |
**频次限制说明:**
-
多客户端接收消息推送API,频次限制200万次/天,申请修改请点击右侧“技术咨询”了解详情。
...
...
@@ -95,8 +96,9 @@ await uniPush.sendMessage(OBJECT)
-
对指定应用的所有用户群发推送消息API,频次限制100次/天,每分钟不能超过5次(推送限制和接口根据条件筛选用户推送共享限制)
**注意:**
-
调用一次sendMessage,最大推送设备数是500,超过将直接忽略。有超过500台以上设备接收消息的应用场景,应当
调用内置在
[
uni-push-admin插件
](
https://ext.dcloud.net.cn/plugin?name=uni-push-admin
)
中的云对象uni-push-co,调用参数与本api一致
-
调用一次sendMessage,最大推送设备数是500,超过将直接忽略。有超过500台以上设备接收消息的应用场景,应当
分批(递归)调用,可以参考
[
uni-push-admin插件
](
https://ext.dcloud.net.cn/plugin?name=uni-push-admin
)
中的云对象uni-push-co
-
`push_clientid`
如果3个月未登陆会失效,所以uni-id的token过期时间不能超过3个月,否则push模块会有意想不到的故障。
-
harmony 平台的api,本地调试仅 HBuilderX 4.31及其以上版本支持
##### getui_big_data_tag 说明@getui-big-data-tag
|名称|类型|是否必需|默认值|描述|
...
...
@@ -147,31 +149,9 @@ await uniPush.sendMessage(OBJECT)
|st|Number|否|无|通道策略1-4,表示含义同上,需要开通st厂商使用该通道推送消息|
|...|Number|否|无|通道策略1-4,表示含义同上|
##### channel 说明@channel
>注意:此功能依赖uni原生插件[点此打开](https://ext.dcloud.net.cn/plugin?id=7482)打包后生效。
|名称|类型|必填|默认值|描述|
|--|--|--|--|--|
|HW|string|否|无|取值为“LOW”时,表示消息为资讯营销;取值为“NORMAL”时,表示消息为服务与通讯。需要先向华为侧发邮件申请权限参见
[
华为消息分类申请
](
https://developer.huawei.com/consumer/cn/doc/development/HMSCore-Guides/message-classification-0000001149358835
)
。|
|XM|string|否|无|小米推送的消息通道分为“普通消息”(默认)和“重要消息”两类,默认下发普通消息。普通消息单日可推送数量有限制,重要消息不限。重要消息申请具体请参考:
[
小米推送消息分类新规
](
https://dev.mi.com/console/doc/detail?pId=2422
)
|
|OP|string|否|无|需要联系客服开通;OPush平台上所有通道分为“公信”(默认)、“私信”两类,默认下发公信消息。公信消息单日可推送数量有限制,私信消息不限(仅限单个用户)。私信消息申请请参见(OPPO官方文档)
[
推送私信通道申请
](
https://open.oppomobile.com/new/developmentDoc/info?id=11227
)
。|
|VV|Number|否|无| 0代表运营消息,1代表系统消息;vivo消息分类功能将推送消息类型分为运营消息和系统消息,默认下发运营消息。运营消息单用户单应用单日接收条数上限为5条,系统消息不限。系统消息功能不用申请,可以直接使用,如特殊情况需额外提升系统消息量级,请参见(vivo官方文档)
[
推送消息分类功能说明
](
https://dev.vivo.com.cn/documentCenter/doc/359
)
。|
例如:
```
js
"
channel
"
:{
"
XM
"
:
"
填写在手机厂商push管理中申请到的值
"
,
"
HW
"
:
"
NORMAL
"
,
"
OP
"
:
"
填写在手机厂商push管理中申请到的值
"
,
"
VV
"
:
1
}
```
##### 铃声设置注意@sound
1.
华为通道须
[
申请自分类权益
](
https://developer.huawei.com/consumer/cn/doc/development/HMSCore-Guides/message-classification-0000001149358835#section3699155822013
)
2.
小米通道需:申请重要级别消息Channel —— 申请其他个性化重要级别消息Channel,并设置自定义铃声前端路径格式:
`android.resource://你的APP应用包名/raw/铃声文件名`
,例如:
`android.resource://io.dcloud.UniPush2/raw/pushsound`
(路径不需要带音频后缀名)如图
![](
https://docs.getui.com/img/img_getui_server_rest_v2_third_party_1.png
)
##### 实现推送铃声@sound
1.
本功能App客户端依赖uni原生插件
[
自定义推送铃声和渠道
](
https://ext.dcloud.net.cn/plugin?id=7482
)
,注意需要打包后生效。铃声文件建议iOS和Android铃声使用一致的文件名称,直接填写文件名,不含扩展名;如:pushsound.caf或pushsound.mp3,直接填写pushsound即可。
2.
Android平台需要在options参数中根据厂商规范配置相关参数,详情参考
[
options示例
](
../uni-cloud-push/options
)
#### 响应体说明
多个别名推送返回值示例:
...
...
docs/uni-cloud-push/options.md
浏览文件 @
7403e539
> 需要HBuilderX 3.5.1 及其以上版本支持
实现部分厂商特定功能,包括仅部分厂商支持、不常用或厂商临时新增的功能(不依赖 uni-push,厂商文档支持的参数可直接使用)。
options 参数主要用于实现部分厂商支持但不常用的功能。详情查看:
[
https://docs.getui.com/getui/server/rest_v2/third_party/
](
https://docs.getui.com/getui/server/rest_v2/third_party/
)
需注意,个推文档中的示例代码与在 uni-push 中的使用存在差异。个推代码示例如下:
例如要实现发送消息时在:
-
安卓系统的小米手机下,实现铃声并对app版本号进行筛选
-
安卓系统的华为手机下,实现铃声并设置富文本内容
-
鸿蒙系统的华为手机下,指定本次推动为测试消息
-
iOS系统下设置灵动岛id
用法为:
```
js
{
"
android
"
:{
"
ups
"
:{
"
notification
"
:{
// ...其他push_channel参数略
const
pushManager
=
uniCloud
.
getPushManager
({
"
appId
"
:
"
__UNI__DEMO123
"
})
return
await
pushManager
.
sendMessage
({
title
:
"
消息标题
"
,
content
:
"
消息内容
"
,
// ...其他参数略,可参考:https://doc.dcloud.net.cn/uniCloud/uni-cloud-push/api.html#%E5%85%A5%E5%8F%82%E8%AF%B4%E6%98%8E
options
:
{
android
:{
"
XM
"
:
{
// 实现铃声
"
/extra.sound_uri
"
:
"
小米后台申请的自定义 sound_url 地址
"
,
"
/extra.channel_id
"
:
"
小米后台申请的通知类别id
"
,
// 对app版本号进行筛选
"
/extra.app_version
"
:
"
v3.3.0
"
},
"
options
"
:{
"
HW
"
:{
"
/message/android/ttl
"
:
"
86400s
"
}
"
HW
"
:{
//实现铃声
"
/message/android/notification/default_sound
"
:
false
,
"
/message/android/notification/channel_id
"
:
"
RingRing4
"
,
"
/message/android/notification/sound
"
:
"
/raw/ring001
"
,
// 设置富文本内容
"
/message/android/notification/image
"
:
"
公网可以访问的https图标链接
"
,
"
/message/android/notification/style
"
:
1
,
"
/message/android/notification/big_title
"
:
"
big_title
"
,
"
/message/android/notification/big_body
"
:
"
big_body
"
}
},
harmony
:{
"
HW
"
:{
"
/pushOptions/testMessage
"
:
true
}
},
ios
:
{
laId
:
"
灵动岛id
"
,
// 略,详情 https://docs.getui.com/getui/server/rest_v2/common_args/#ios-
}
}
}
}
)
```
而 uni-push 简化了代码,无需 “android.ups”。例如,要实现发送消息时在小米通道上对 app 版本号进行筛选,完整示例代码为:
更多用法参规范:
-
Android和harmony查看:
[
https://docs.getui.com/getui/server/rest_v2/third_party/
](
https://docs.getui.com/getui/server/rest_v2/third_party/
)
-
ios节点的参数规范查看
[
https://docs.getui.com/getui/server/rest_v2/common_args/#ios-
](
https://docs.getui.com/getui/server/rest_v2/common_args/#ios-
)
options参数对照
[
个推push完整请求体
](
https://docs.getui.com/getui/server/rest_v2/common_args/#doc-title-2
)
的关系如下:
|uni-push |个推 |
|-- |-- |
| android |push_channel.android.ups.options |
| harmony |push_channel.harmony.options |
| ios |push_channel.ios |
::: warning 注意事项
以上为HBuilderX 4.31及其以上版本中的用法,旧版版本中的用法为:
:::
```
js
const
pushManager
=
uniCloud
.
getPushManager
({
"
appId
"
:
"
__UNI__TEST123
"
})
return
await
pushManager
.
sendMessage
({
...
...
@@ -30,13 +70,15 @@ return await pushManager.sendMessage({
options
:
{
"
XM
"
:
{
"
/extra.app_version
"
:
"
v3.3.0
"
}
},
"
HW
"
:{},
"
VV
"
:{},
"
OP
"
:{},
"
IOS
"
:{}
}
})
```
此用法不再维护且不再推荐使用(因为无法准确表述Android系统的华为通道,还是鸿蒙系统的华为通道;且不支持ios灵动岛推送)。
<div
class=
"weixin-support"
>
<div
class=
"weixin-support-focus"
>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录