unipush-v2.md 23.5 KB
Newer Older
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
1 2 3
# uni-push2统一推送

> 本文为uni-push2.0(需要HBuilderX 3.5.1 及其以上版本支持)的介绍,如果旧项目需要使用老版本的uniPush1.0,另见:[https://ask.dcloud.net.cn/article/35622](https://ask.dcloud.net.cn/article/35622)
DCloud_JSON's avatar
DCloud_JSON 已提交
4 5 6 7 8 9 10 11 12 13 14 15 16

# 应用场景
以下功能可以用uni-push 实现  
- 用户消息通知  
当 APP 用户相关状态或者系统功能状态变化时(如用户订单通知、交易提醒、物流通知、升级提醒、社交互动提醒等),可对用户进行及时告知,或者促使用户完成特定操作。

- 离线语音播报  
它也是一种用户消息推送,实现原理其实是自定义通知提醒铃声

- 营销促活通知  
在日常营销推广、促销活动等场景下(如双11大促、产品上新、重要资讯等),APP可对目标用户进行定向通知栏消息+应用内消息推送,吸引用户参与活动,提升日活。

- 基于uniCloud的IM、聊天、客服、棋牌游戏交互等  
DCloud_JSON's avatar
DCloud_JSON 已提交
17
例如:DCloud基于`uni-push2`开发并开源了`uni-im`详情:[https://uniapp.dcloud.net.cn/uniCloud/uni-im.html](https://uniapp.dcloud.net.cn/uniCloud/uni-im.html)  
DCloud_JSON's avatar
DCloud_JSON 已提交
18 19 20 21 22
另外棋牌游戏等,需要客户端被动接收消息的需求都可以用`uni-push`实现。

# 简介

## 概述
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
23 24 25 26
`uni-push`是DCloud推出的、全端的、云端一体的统一推送服务。

1. 客户端方面,`uni-push2`支持App、web、小程序。
  * App端,内置了苹果、华为、小米、OPPO、VIVO、魅族、谷歌FCM等手机厂商的系统推送和个推第三方推送
D
DCloud_LXH 已提交
27
  * 小程序端,内置了socket在线推送。如需模板消息/订阅消息,另见[uni-subscribemsg](/uniCloud/uni-subscribemsg.md)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
28 29 30 31
  * web端,内置了socket在线推送
  (uni-push1仅支持app,且app必须包含个推原生sdk。uni-push2在app端如不需要厂商推送,只需在线推送,无需集成个推原生sdk)
2. 服务端方面,`uni-push2`支持uniCloud云端一体,无需再编写复杂代码轻松完成push。
  (uni-push1.0仅支持使用传统服务器开发语言如php,未和客户端有效协同,流程比uni-push2.0繁琐)
DCloud_JSON's avatar
DCloud_JSON 已提交
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
3. uni-push还自带一个web控制台。不写代码也可以在web页面发推送。uni-push1.0的web控制台在[dev.dcloud.net.cn](https://dev.dcloud.net.cn)。uni-push2.0的web控制台是开源的,属于uni-admin插件[详见](https://ext.dcloud.net.cn/plugin?name=uni-push-admin)

## 什么是push?
push,指服务器主动向客户端发送消息的技术。无需客户端持续轮询服务器,即可获得即时数据。

轮询有很多弊端:1) 客户端应用必须实时在线;2) 手机端耗电严重;3) 服务器负载高且浪费资源

手机的通知栏、小程序的订阅消息都是一种push,由手机操作系统或微信在底层提供了push通道,屏蔽了轮询的各种弊端。你的应用可以被关闭,只要手机有网,操作系统提供的push通道即是实时在线的。

提醒:web浏览器的webnotification其实是一个本地通知栏功能,浏览器厂商没有提供push通道。

当客户端在线时,push通过socket协议实现。当客户端离线时,服务器找不到客户端,开发者无法自己实现推送,只能依托手机操作系统、小程序底层提供的离线消息推送,调用指定的手机厂商或小程序厂商的服务器接口来发送消息。

所以一个push系统需要3部分协作:开发者的业务服务器 + 专业push服务器 + 开发者的客户端应用。

其主要流程是:

1. 开发者的业务服务器向专业push服务器发送指令,告知需要向哪些客户端发送什么样的消息
2. 专业push服务器再向客户端发送消息
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
51
3. 若手机应用在线,直接收到push;若不在线,手机用户在操作系统的通知栏中看到push消息,点击后呼起客户端应用,客户端代码可以接收响应获得消息;如果是小程序的话,则是在微信消息里看到订阅消息,点击后呼起小程序并拿到启动参数。
DCloud_JSON's avatar
DCloud_JSON 已提交
52
<div style="float:clear;">
study夏羽's avatar
study夏羽 已提交
53 54
	<img width="30%" style="margin-left:5%;max-width:260px;" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/20220325203150.jpg"/>
	<img width="30%" style="margin-left:5%;max-width:260px;" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/3bb2b4c4-1b73-426d-b713-f076aff80868.jpg"/>
DCloud_JSON's avatar
DCloud_JSON 已提交
55 56 57 58
</div>

由于手机厂商众多,他们各自都有不同的推送服务,包括Apple、google(仅能在海外使用)、华为、小米、oppo、vivo、魅族,以及还有一些没有专业推送服务的中小手机品牌。他们对App后台耗电都有查杀机制,除了微信等大应用,普通应用很难常驻后台。

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
59
如果开发者把上述每个平台的客户端和服务器的SDK都对接一遍,还自己处理没有push服务的中小品牌手机,那过于困难了。所以业内有专业的推送服务厂商把各种手机厂商的通道封装成一套统一的API,如个推(属于上市公司每日互动);同时这些三方专业推送厂商还提供了高速socket通道。当应用在线时,也可以直接通过socket下发消息。否则开发者需要写很多判断代码、搭建socket服务器、处理在线时和离线时各种差异。
DCloud_JSON's avatar
DCloud_JSON 已提交
60

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
61
DCloud与个推(A股上市公司每日互动)深度合作,为uni-app的开发者提供了比传统方案便利甚多的统一推送方案`uni-push2`,利用云端一体的优势,同时提供基于uniCloud的push服务器和基于uni-app的push客户端,两者高效协同,极大的简化了push的使用。
DCloud_JSON's avatar
DCloud_JSON 已提交
62

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
63
> 注:`uni-push`的服务器稳定性是由阿里云serverless、腾讯云serverless、个推来保障的,都是日活过亿的上市公司,无需顾虑稳定性。
DCloud_JSON's avatar
DCloud_JSON 已提交
64 65 66 67 68

如下图所示:
首先开发者的uniCloud应用服务器向uniPush服务器发送push消息,然后
- 如果客户端应用在线,客户端通过socket直接收到push在线消息;
- 客户端应用不联网时,`uni-push`服务器根据客户端类型,把push消息发给某个手机厂商的push服务器或小程序的订阅消息服务器;然后厂商push通道会把这条消息发到手机的通知栏或微信的订阅消息里;手机用户点击通知栏消息或小程序订阅消息后,启动App或小程序,客户端才能收到离线消息。
study夏羽's avatar
study夏羽 已提交
69
	<img width="100%" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/cd3e676a-6a3b-44ea-9045-5bc058d0d8ae.png"/></br>
DCloud_JSON's avatar
DCloud_JSON 已提交
70 71 72 73 74


总结下`uni-push`提供的功能:
1. 一个在线的socket下行服务,无论app、小程序、web,只要在线,都可以从服务器推送消息。尤其对于uniCloud用户,这个免费socket下行服务用途很多。
2. app平台,提供app离线时的推送,聚合了所有已知手机厂商的push通道;对于未提供push通道的小手机厂商,提供后台常驻进程接收push消息(受手机rom节电设置约束)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
75 76 77
3. 小程序平台,目前提供了下行socket通道,后续会整合小程序离线时的订阅消息
4. web平台,目前提供了下行socket通道,后续会提供webnotification的封装。当标签卡在后台时(注意不是关闭时),仍然可以在屏幕上弹出通知栏。
5. 快应用平台,目前提供了下行socket通道,后续会提供离线push的封装
DCloud_JSON's avatar
DCloud_JSON 已提交
78 79
6. 一个[uni-admin](/uniCloud/admin)插件,开源的web控制台,无需编程,可视化界面发送push消息 [详见](https://ext.dcloud.net.cn/plugin?name=uni-push-admin)

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
80
[uni-starter](/uniCloud/uni-starter)里,还提供了app push权限判断、申请、开关设置,搭配使用可以大量降低开发工作量。
DCloud_JSON's avatar
DCloud_JSON 已提交
81 82 83 84 85

注意:app申请创建通知栏消息、web申请弹出通知,均会由操作系统或浏览器自动弹窗询问用户是否同意。小程序下需要手机用户主动发起订阅行为,才能送达消息。

`uni-push`即降低了开发成本,又提高了push送达率,还支持全平台,并且免费,是当前推送的最佳解决方案。

DCloud_JSON's avatar
DCloud_JSON 已提交
86
## uni-push2.0 使用uniCloud产生的费用说明@cost
DCloud_JSON's avatar
DCloud_JSON 已提交
87 88 89 90 91 92 93

uni-push本身并不收费,实际使用中需要依赖uniCloud云服务,而uniCloud价格很实惠:  
- 调用10000次云函数仅需0.0133元
- 调用10000次数据库查询仅需0.015元

可见价格之低,几乎可以忽略不计。

DCloud_JSON's avatar
DCloud_JSON 已提交
94
一次消息推送 = 1次云函数请求 + 最高3次数据库查询(最常用的基于user_id推送仅需一次查询,详情参考:[推送接口查库详解](https://uniapp.dcloud.net.cn/uniCloud/uni-cloud-push/mate.html#%E6%8E%A8%E9%80%81%E6%8E%A5%E5%8F%A3%E6%9F%A5%E5%BA%93%E8%AF%A6%E8%A7%A3) )  
DCloud_JSON's avatar
DCloud_JSON 已提交
95

DCloud_JSON's avatar
DCloud_JSON 已提交
96
即:最高(1 * 0.0133 + 3 * 0.015)/10000 = 0.00000583元/每次(注:给你的应用的所有注册用户群发消息算一次)  
DCloud_JSON's avatar
DCloud_JSON 已提交
97 98 99

详细的计费参考:[阿里云版uniCloud按量计费文档](https://uniapp.dcloud.net.cn/uniCloud/price.html#aliyun-postpay)

DCloud_JSON's avatar
DCloud_JSON 已提交
100 101 102 103 104
# 常见问题
有了uni-push,开发者不应该再使用其他push方案了。但我们发现很多开发者有误解,导致还在错误使用其他推送。

- 常见误解1:“uni-push的专业性,和专业的个推、极光等服务可相比吗?”

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
105
	答:uniPush 是由个推将其本来收费的 push 产品,免费提供给了DCloud的开发者。它与个推vip push的只有3个区别:1、免费;2、账户使用的是DCloud开发者账户,而无需再重新注册个推账户;3、开发文档看DCloud的。
DCloud_JSON's avatar
DCloud_JSON 已提交
106 107 108 109 110 111 112 113 114 115 116 117 118

- 常见误解2:“uni-push好麻烦,我就喜欢个推、极光这种简单sdk,不想去各个rom厂商去申请一圈”

	答:uni-push不建立在申请手机厂商授权的基础上,如果你不申请那些,使用起来和用普通的push是一样的。但是要特别注意,推送行业的现状就是:不集成rom厂商的推送,就无法在App离线时发送push。按照普通push模式使用,后果就是在华为、小米、OPPO、VIVO、魅族上发不了离线消息。

- 常见误解3:“uni-push的送达率高吗?是否可以付费来提升送达率,个推是有付费提升送达率的方法的”

	答:前文已经说了。个推的付费提升送达率的产品就是vip push,而uni-push就是个推的vip Push。DCloud通过谈判免费给DCloud的开发者使用了。

- uni-push可以完整替代socket吗?

	答:能部分替代。uni-push客户端接收消息的通讯协议属于websocket;但业务服务端向uniPush服务发送消息用的是http通讯协议,会有1-2秒的延时。需要超低延迟的应用场景,如多人交互远程画板不合适。但对于普通的im消息、聊天、通知都没有问题。

DCloud_JSON's avatar
DCloud_JSON 已提交
119 120
- 5+app和wap2app支持uni-push2.0吗?  
	
DCloud_JSON's avatar
DCloud_JSON 已提交
121 122
	答:暂不支持。

DCloud_JSON's avatar
DCloud_JSON 已提交
123
- **使用有其他疑问**,欢迎扫码加入 uni-push2.0 微信交流群讨论:
124
    <br/><img src="https://ask.dcloud.net.cn/uploads/article/20210219/f0fca7f4ea8b8650386fc20345312105.JPG" width="250"/>
DCloud_JSON's avatar
DCloud_JSON 已提交
125

DCloud_JSON's avatar
DCloud_JSON 已提交
126
# 快速上手
DCloud_JSON's avatar
DCloud_JSON 已提交
127
## 第一步:开通  
DCloud_JSON's avatar
DCloud_JSON 已提交
128
uni-push产品有2个入口:
DCloud_JSON's avatar
DCloud_JSON 已提交
129
1. 通过 HBuilderX(3.5.1及其以上版本)进入
DCloud_JSON's avatar
DCloud_JSON 已提交
130 131

	打开 HBuilderX,双击项目中的 “manifest.json” 文件,选择“App 模块配置”,向下找到“Push(消息推送)”,勾选后,点击 “uniPush” 下面的配置链接。如下图所示:
study夏羽's avatar
study夏羽 已提交
132
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/20220525104554.jpg)
DCloud_JSON's avatar
DCloud_JSON 已提交
133 134 135
2. 通过开发者中心进入
	
	使用 HBuilder 账号登录 [开发者中心](https://dev.dcloud.net.cn) ,登录后
Anne_LXM's avatar
Anne_LXM 已提交
136
	会进入“uniPush”-“Uni Push 2.0(支持全端推送)”-“应用信息”,点击“当前应用”选择要操作的应用。
DCloud_JSON's avatar
DCloud_JSON 已提交
137 138
	
以上两种方式均可进入uniPush 应用开通界面。如下图所示:
study夏羽's avatar
study夏羽 已提交
139
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/uniPush2-info.jpg)
DCloud_JSON's avatar
DCloud_JSON 已提交
140 141 142 143 144

### 手机号验证

按照国家法律要求,所有提供云服务的公司在用户使用云服务时都需要验证手机号。

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
145
用户初次开通 uni-push 时,需要向个推同步手机号信息(DCloud开发者无需再注册个推账户)。
D
DCloud_LXH 已提交
146
![](https://img-cdn-aliyun.dcloud.net.cn/uni-app/doc/dev/sm.png)
DCloud_JSON's avatar
DCloud_JSON 已提交
147 148 149

### 填写应用信息
应用开通 uni-push 功能时,需要提交应用相关信息,如下图所示:
study夏羽's avatar
study夏羽 已提交
150
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/uniPush2-info.jpg)
DCloud_JSON's avatar
DCloud_JSON 已提交
151

DCloud_JSON's avatar
DCloud_JSON 已提交
152
关联服务空间说明:uni-push2.0需要开发者开通uniCloud。不管您的业务服务器是否使用uniCloud,但专业推送服务器在uniCloud上。
DCloud_JSON's avatar
DCloud_JSON 已提交
153 154 155 156

- 如果您的后台业务使用uniCloud开发,那理解比较简单。
- 如果您的后台业务没有使用uniCloud,那么也需要在uni-app项目中创建uniCloud环境,在HBuilderX中和dev的uni-push配置中均绑定相同服务空间,之前的业务仍然由客户端连接原有传统服务器,push相关功能则通过uniCloud服务空间实现。如果您之前使用过三方推送服务的话,可以理解为您的服务器不再调用个推服务器,而是改为调用uniCloud服务空间。

157
在uniCloud的云函数中,加载扩展库 `uni-cloud-push`,直接调用相关API,无需额外的服务端配置。而传统服务器开发者需要把这个[云函数URL化](https://uniapp.dcloud.io/uniCloud/http.html)后变成http接口,再由原来的php或java代码调用这个http接口。
DCloud_JSON's avatar
DCloud_JSON 已提交
158 159 160 161 162 163 164

注意:`Android包名、签名(SHA1指纹)``iOS Bundle ID`,必须确保与客户端manifest.json配置的证书相关信息一致,否则可能会导致无法正常打包或收到推送消息。

参考资料:[关于Android证书](https://ask.dcloud.net.cn/article/35985#server)[iOS证书申请](https://ask.dcloud.net.cn/article/152)

开通完成后,后续仍可以在这里修改以上信息。

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
165 166
开通App的完整流程较多,但开通web和小程序的流程比较简单,即开即用。可以快速将uni-app项目运行到浏览器或小程序体验。

DCloud_JSON's avatar
DCloud_JSON 已提交
167
## 第二步:配置  
DCloud_JSON's avatar
DCloud_JSON 已提交
168 169 170
- iOS 平台还需要上传专用的推送证书
	+ 证书申请:如何获取推送证书请参考个推官方文档教程 [iOS证书配置指南](https://docs.getui.com/getui/mobile/ios/apns/)
	+ 证书上传入口:消息推送-“配置管理”-“应用配置”
D
DCloud_LXH 已提交
171
![](https://img-cdn-aliyun.dcloud.net.cn/uni-app/doc/dev/ios.png)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
172
- APP手机厂商推送参数设置(可选,应用进程离线时推送通道)
D
DCloud_LXH 已提交
173
	![](https://img-cdn-aliyun.dcloud.net.cn/uni-app/doc/dev/20220728173149.png)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
174
	uniPush集成并统一了各个手机厂商的系统级推送,目前支持魅族、OPPO、华为、小米、VIVO。如果需要使用厂商推送,需要先在各厂商开发者平台申请。详见[厂商推送应用创建配置流程](https://www.dcloud.io/docs/a/unipush/manufacturer.pdf)
DCloud_JSON's avatar
DCloud_JSON 已提交
175 176 177 178 179


## 第三步:客户端操作
### 名词解释
#### 离线推送@offline
study夏羽's avatar
study夏羽 已提交
180
<img width="30%" style="margin-left:20px;margin-top:0;float:right;" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/20220325203150.jpg"/>
Anne_LXM's avatar
Anne_LXM 已提交
181

DCloud_JSON's avatar
DCloud_JSON 已提交
182 183 184 185 186 187 188 189 190
仅APP端支持,当应用被用户关闭,或者运行到后台时,手机厂商为了省电或释放内存,会终止App后台联网。

消息将通过不会离线的手机厂商通道,下发到手机系统推送服务模块;

此时客户端会自动创建通知栏消息,展示在系统消息中心(如图所示)但客户端监听不到消息内容;当用户点击通知栏消息后,会将APP唤醒此时APP才能监听到消息内容。

#### 在线推送@online
当应用在线时,不会创建“通知栏消息”,此时客户端会立即监听到消息内容。

191
如果你希望当应用在线时,也通过“通知栏消息”来提醒用户;可以通过以下两种方式实现:
DCloud_JSON's avatar
DCloud_JSON 已提交
192
1. 监听到消息内容后,根据业务需要自己判断是否要创建“通知栏消息”,需要就调用创建本地消息API [uni.createPushMessage](https://uniapp.dcloud.net.cn/api/plugins/push.html#createpushmessage)手动创建通知栏消息。
193
2. 服务端执行推送时,传递参数`force_notification:true`,客户端就会自动创建“通知栏消息”(此时你监听不到消息内容),当用户点击通知栏消息后,APP才能监听到消息内容。
DCloud_JSON's avatar
DCloud_JSON 已提交
194

DCloud_JSON's avatar
DCloud_JSON 已提交
195
以上两种方案各有优劣,方案一更加灵活;比如:客服功能,客户端接收到聊天消息时,应用如果已经打开聊天对话页面,就直接将监听到的推送内容,渲染到页面。如果应用未打开聊天页,则调用api创建“通知栏消息”提醒用户;此时你还可以执行一些其他逻辑,比如将tabBar的消息中心加红点等。方案二比较简便,客户端无需额外编写代码,自动创建通知栏消息;但仅适用于不关心客户端行为就创建“通知栏消息”的场景,如广告营销内容的推送等。
DCloud_JSON's avatar
DCloud_JSON 已提交
196

DCloud_JSON's avatar
DCloud_JSON 已提交
197
### 客户端启用uniPush2.0
198

DCloud_JSON's avatar
DCloud_JSON 已提交
199
操作步骤打开`manifest.json` - `App模块配置` - 中勾选`uniPush 2.0` - `重新编译项目`
study夏羽's avatar
study夏羽 已提交
200 201 202
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/20220525105852.jpg)
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/20220525105914.jpg)
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/87accaa0-e6a4-4916-9a74-87719142abaa.jpg)
DCloud_JSON's avatar
DCloud_JSON 已提交
203 204
其他小程序启用方式参考微信小程序,这里不一一列举

DCloud_JSON's avatar
DCloud_JSON 已提交
205 206
`manifest.json`中配置完之后,需要重新编译项目,即:点击如图`重新运行`按钮

study夏羽's avatar
study夏羽 已提交
207
<img width="50%" style="max-width:260px;" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/WechatIMG589.jpeg"/>
DCloud_JSON's avatar
DCloud_JSON 已提交
208 209


DCloud_JSON's avatar
DCloud_JSON 已提交
210 211 212 213 214 215
#### 小程序中使用uni-push2.0的白名单配置@useinmp

uni-push在web和小程序端就是个websocket;各家小程序平台,均要求在小程序管理后台配置小程序应用的联网服务器域名,否则无法联网。

根据下表,在小程序管理后台设置socket合法域名。下表的域名均为个推自有域名,并非DCloud所属域名。

DCloud_JSON's avatar
DCloud_JSON 已提交
216
- HBuilderX 3.6.15以下版本(小程序和web端 WebSocket连接不稳定,请尽快升级)
DCloud_JSON's avatar
DCloud_JSON 已提交
217

DCloud_JSON's avatar
DCloud_JSON 已提交
218 219 220 221 222
|域名|端口|
|--	|--	|
|wshz.getui.net|5223|
|wshz.gepush.com|5223|

DCloud_JSON's avatar
DCloud_JSON 已提交
223

DCloud_JSON's avatar
DCloud_JSON 已提交
224
- HBuilderX 3.6.15及以上版本
DCloud_JSON's avatar
DCloud_JSON 已提交
225

DCloud_JSON's avatar
DCloud_JSON 已提交
226 227 228
|域名|端口|
|--	|--	|
|wshzn.gepush.com |5223|
DCloud_JSON's avatar
DCloud_JSON 已提交
229
|wshzn.getui.net |5223(3.8.5新增)|
DCloud_JSON's avatar
DCloud_JSON 已提交
230

DCloud_JSON's avatar
DCloud_JSON 已提交
231

DCloud_JSON's avatar
DCloud_JSON 已提交
232 233 234
### 客户端监听推送消息@listener  
监听推送消息的代码,需要在收到推送消息之前被执行。所以应当写在应用一启动就会触发的[应用生命周期](https://uniapp.dcloud.io/collocation/App.html#applifecycle)`onLaunch`中。

235
示例代码:
DCloud_JSON's avatar
DCloud_JSON 已提交
236
```js 
DCloud_JSON's avatar
DCloud_JSON 已提交
237
//文件路径:项目根目录/App.vue
238 239 240
export default {
	onLaunch: function() {
		console.log('App Launch')
241
		uni.onPushMessage((res) => {
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
242
			console.log("收到推送消息:",res) //监听推送消息
243
		})
244 245 246 247 248 249 250 251
	},
	onShow: function() {
		console.log('App Show')
	},
	onHide: function() {
		console.log('App Hide')
	}
}
DCloud_JSON's avatar
DCloud_JSON 已提交
252 253
```

Anne_LXM's avatar
Anne_LXM 已提交
254
> 先跟着示例代码简单体验,详细的uni.onPushMessage API介绍[详情参考](/api/plugins/push.html#onpushmessage)
DCloud_JSON's avatar
DCloud_JSON 已提交
255 256

**APP端真机运行注意:** 
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
257
- 如果启用了离线推送,必须:经过发行原生app云打包后,客户端才能监听到推送消息。标准HBuilder运行基座无法使用。
DCloud_JSON's avatar
DCloud_JSON 已提交
258
- 离线推送时,Android手机厂商通道推送[需设置消息渠道id](/uniCloud/uni-cloud-push/api.html#channel),否则会被限制频次和静默推送(静音且需下拉系统通知栏才可见)
259 260
- 如果Android应用进入后台后(App未销毁),点击通知消息无法拉起App,请检查设备是否有禁止后台弹出界面,路径>>设置-应用管理-测试应用-权限管理-后台弹出界面,(一般是小米、oppo、
vivo设备)。
DCloud_JSON's avatar
DCloud_JSON 已提交
261

DCloud_JSON's avatar
DCloud_JSON 已提交
262 263 264
### 获取客户端推送标识  
假如我要给“张三”打电话,那就需要知道对方的电话标识,即电话号码是多少。
同理,要给某个客户端推送消息,也需要知道该设备的客户端推送标识。
DCloud_JSON's avatar
DCloud_JSON 已提交
265

Anne_LXM's avatar
Anne_LXM 已提交
266
> 先跟着示例代码简单体验,详细的uni.getPushClientId API介绍[详情参考](/api/plugins/push.md)
DCloud_JSON's avatar
DCloud_JSON 已提交
267
代码示例:
D
DCloud_LXH 已提交
268
```js
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
269
// uni-app客户端获取push客户端标记
DCloud_JSON's avatar
DCloud_JSON 已提交
270 271 272 273 274 275 276 277 278 279
uni.getPushClientId({
	success: (res) => {
		let push_clientid = res.cid
		console.log('客户端推送标识:',push_clientid)
	},
	fail(err) {
		console.log(err)
	}
})
```
DCloud_JSON's avatar
DCloud_JSON 已提交
280 281 282
## 第四步:服务端推送消息  
消息推送属于敏感操作,只能直接或间接由服务端触发。传统的三方push服务,需要开发者在服务端配置密钥或证书,根据服务器端文档签名获取token,再向相关URL接口发起网络请求......

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
283
而UniPush2.0,开发者无需关心证书、签名、服务器端文档,使用简单。云函数通过 uni-push服务端sdk,即`uni-cloud-push`的API即可直接执行uniPush所有操作。
DCloud_JSON's avatar
DCloud_JSON 已提交
284 285 286 287

uni-push的服务端sdk的体积不小,没有内置在云函数中。在需要操作uni-push的云函数里,开发者需手动配置`uni-cloud-push`扩展库。
(uniCloud扩展库,是uniCloud自带API中不常用且包体积较大的部分,被独立为扩展库,可以由开发者自行选择是否使用该扩展库)

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
288
- HBuilderX 中新建云函数时可选择uni-cloud-push扩展库,或者如下图所示在已有的云函数目录点右键选择“管理公共模块或扩展库依赖”
DCloud_JSON's avatar
DCloud_JSON 已提交
289

study夏羽's avatar
study夏羽 已提交
290
<img style="width:80%;max-width:600px;margin:0 10%" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/uniPush-glkzk.jpg"/>
DCloud_JSON's avatar
DCloud_JSON 已提交
291
</br>
study夏羽's avatar
study夏羽 已提交
292
<img style="width:80%;max-width:450px;margin:0 10%" src="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/uniPush-kzk.jpg"/>
DCloud_JSON's avatar
DCloud_JSON 已提交
293
</br>
DCloud_JSON's avatar
DCloud_JSON 已提交
294 295

下面是一个开启了`uni-cloud-push`扩展库的云函数的package.json示例,**注意不可有注释,以下文件内容中的注释仅为说明,如果拷贝此文件,切记去除注释**
DCloud_JSON's avatar
DCloud_JSON 已提交
296

D
DCloud_LXH 已提交
297
```json
DCloud_JSON's avatar
DCloud_JSON 已提交
298 299 300 301 302 303 304 305 306 307 308 309
{
	"name": "test",
	"version": "1.0.0",
	"description": "",
	"main": "index.js",
	"extensions": {
		"uni-cloud-push": {} // 配置为此云函数开启uni-cloud-push扩展库,值为空对象留作后续追加参数,暂无内容
	},
	"author": ""
}
```

DCloud_JSON's avatar
DCloud_JSON 已提交
310
**注意:扩展库依赖3张opendb表:`opendb-tempdata`,`opendb-device`,`uni-id-device`。公测版uniCloud,执行扩展库会自动创建。如果你使用的是uniCloud正式版需要自己创建这3张表。**
DCloud_JSON's avatar
DCloud_JSON 已提交
311

DCloud_JSON's avatar
DCloud_JSON 已提交
312 313 314 315 316
云函数中调用uni-cloud-push扩展库的`sendMessage`方法,向客户端推送消息

```js
// 简单的使用示例
'use strict';
DCloud_JSON's avatar
DCloud_JSON 已提交
317
const uniPush = uniCloud.getPushManager({appId:"__UNI__XXXXXX"}) //注意这里需要传入你的应用appId,用于指定接收消息的客户端
DCloud_JSON's avatar
DCloud_JSON 已提交
318 319
exports.main = async (event, context) => {
	return await uniPush.sendMessage({
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
320
		"push_clientid": "xxx", 	//填写上一步在uni-app客户端获取到的客户端推送标识push_clientid
DCloud_JSON's avatar
DCloud_JSON 已提交
321 322
		"title": "通知栏显示的标题",	
		"content": "通知栏显示的内容",
DCloud_JSON's avatar
DCloud_JSON 已提交
323
		"payload": {
DCloud_JSON's avatar
DCloud_JSON 已提交
324 325
			"text":"体验一下uni-push2.0"
		}
DCloud_JSON's avatar
DCloud_JSON 已提交
326 327 328 329
	})
};
```

DCloud_JSON's avatar
DCloud_JSON 已提交
330
在云函数文件目录右键(或按快捷键ctrl + r)-> `运行-本地云函数`,此时你的客户端将收到推送消息(应用关闭时为通知栏消息,在线时代码监听到推送消息)
DCloud_JSON's avatar
DCloud_JSON 已提交
331

Anne_LXM's avatar
Anne_LXM 已提交
332
> 先跟着示例代码简单体验一下,详细的uniPush.sendMessage API介绍[详情参考](/uniCloud/uni-cloud-push/api.html#uni-cloud-push)
DCloud_JSON's avatar
DCloud_JSON 已提交
333

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
334
如果按步骤操作完毕,此时你运行起来的uni-app客户端就会打印出“收到推送消息:xxxx”。如遇异常,可以重新运行一遍。
DCloud_JSON's avatar
DCloud_JSON 已提交
335 336

# 最佳实践
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
337
上一章,演示了基于“客户端推送标识”的消息推送,仅为方便理解和体验;在业务开发中,通常是指定消息的接收人,而不是某个设备。
DCloud_JSON's avatar
DCloud_JSON 已提交
338 339

如果项目使用[uni-id-pages](https://ext.dcloud.net.cn/plugin?id=8577),即可直接指定基于uni-id的user_id、user_tag,并可筛选设备的平台、登录信息是否有效等,执行推送消息。
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
340

DCloud_JSON's avatar
DCloud_JSON 已提交
341
uni-id-pages已经内置:在登录账号、退出账号、切换账号、token续期、注销账号5个时机,管理uni-id-device表、opendb-device表与user_id、push_clientid、platform、os_name等字段的映射关系。[详情参考](/uniCloud/uni-cloud-push/mate)
DCloud_JSON's avatar
DCloud_JSON 已提交
342

DCloud_JSON's avatar
DCloud_JSON 已提交
343
此外uni-push2.0 还提供了uni-admin中的web控制台[uni-push-admin](https://ext.dcloud.net.cn/plugin?name=uni-push-admin)。如图,包含消息推送、推送统计等功能的,
DCloud_JSON's avatar
DCloud_JSON 已提交
344

study夏羽's avatar
study夏羽 已提交
345
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/f981f620-f9de-11ec-8412-6b7a68f609ab_0.jpg)