越来越多的CP在AGC上上架了快应用之后,希望吸引越多的用户,提高应用的活跃度,从而带来更多的流量,最终实现他们的商业价值。快应用提供了标准的Push能力,开发者可以给用户推送消息,比如推送一本好书、推送一个美食等,点击消息可以拉起快应用。
商城类快应用通过接入Push,给用户推送心仪商品的降价通知。
场景二:阅读阅读类的快应用通过接入Push,给用户推荐好书、章节更新等消息,让用户第一时间得到最新进展。
场景三: 美食美食类快应用通过接入Push,给用户推荐好吃的东西、推荐好的餐馆,方便了用户,也给餐饮业带来了知名度和商业利益。
华为推送(Push)是为开发者提供的消息推送平台,建立了从云端到手机端的消息推送通道,让应用可以将最新信息及时通知到用户,从而构筑良好的用户关系,提升用户的感知和活跃度。
快应用Push功能在EMUI8.0及以上版本的手机上支持。
发送PUSH消息的流程如下图所示:
Push接口介绍:
模块名:service.push
模块引入:import push from ‘@service.push’ 或 var push = require("@service.push")
支持的接口:
硬件要求
一台计算机(需要安装好Quick App IDE)。
一部华为手机(带USB数据线),用于运行开发的应用程序,EMUI 8.0及以上。
软件要求
PC上安装Node.js 10以上
PC上安装Quick App IDE最新版本
其他要求
在华为开发者联盟申请PUSH服务,具体操作请参见:开通Push服务。需要的知识点
Javascript+css调用 push.getProvider 接口判断当前设备是否支持华为PUSH服务,接口返回 huawei 表示支持,否则表示不支持。后续Push其他接口调用必须在设备支持PUSH服务的前提进行。
调用 push.subscribe 接口获取regId。regId也被称为token或push token,是用于发送push消息的标识。
注意:以上接口推荐在全局app.ux中调用。
示例代码如下:
checkPushIsSupported(){ let provider= push.getProvider(); console.log("checkPush provider= "+provider); if(provider==='huawei'){ this.pushsubscribe(); } }, pushsubscribe() { console.log("pushsubscribe start"); var that=this; push.subscribe({ success: function (data) { console.log("push.subscribe succeeded, result data=" + JSON.stringify(data)); that.dataApp.pushtoken=data.regId; }, fail: function (data, code) { console.log("push.subscribe failed, result data=" + JSON.stringify(data) + ", code=" + code); }, complete: function () { console.log("push.subscribe completed"); } }) },将2中获取到的regId通过快应用fetch接口上报到快应用自己的业务服务器,用于后续服务器向快应用发送push消息。 regId一般情况下不会发生变化,不需要每次获取后都上报到服务器。
推荐做法:使用快应用storage接口本地存储regId,每次获取到regId时先和本地存储的对比,相等则不上报到业务服务器,不相等说明发生变化了,需要上报到业务服务器。流程图如下图所示: Push token与本地缓存对比的代码逻辑如下:
checkToken() { var subscribeToken=this.$app.$def.dataApp.pushtoken; console.log(“checkToken subscribeToken= ”+subscribeToken); var storage = require("@system.storage"); var that=this; storage.get({ key: 'token', success: function (data) { console.log("checkToken handling success data= "+data); if (subscribeToken != data) { //上报到自己的业务服务器 that.uploadToken(subscribeToken); that.saveToken(subscribeToken); } }, fail: function (data, code) { console.log("handling fail, code = " + code); } }) },上传到开发者业务服务器示例代码如下:
uploadToken(subscribeToken) { console.log("uploadToken"); var that = this; var body = { xx: subscribeToken }; fetch.fetch({ url: 'https://xxx', method: 'POST', data: body, success: function (data) { console.log("uploadToken code: " + data.code); console.log("uploadToken data: " + data.data); }, fail: function (data, code) { console.log("handling fail, code = " + code); } }) },注意事项:以上示例代码中的fetch接口调用中的参数需要替换业务自己的服务器地址。fetch接口更多内容请参考官网API fetch。
Pushtoken保存到本地代码如下:
saveToken(subscribeToken){ console.log("saveToken"); var storage = require("@system.storage"); storage.set({ key: 'token', value: subscribeToken, success: function (data) { console.log("saveToken handling success"); }, fail: function (data, code) { console.log("saveToken handling fail, code = " + code); } }) },客户端的开发流程已经结束了,是不是很easy?接下来,怎么给手机上推送消息测试呢?这个时候pushtoken就非常重要了,它是唯一标识设备的标志,有了它,push服务可以准确把消息发送到正确的手机和应用上。手机上接收通知栏消息需要满足如下条件之一:
在桌面有快捷方式的快应用
加入“我的快应用”的快应用
有使用记录的快应用
快应用处于运行状态
目前可以通过下面两种方式来发送Push消息:
在华为开发者联盟发送:适用选取部分目标用户发送,支持推送到现网的快应用(已经在应用市场上上架)和加载器上运行的快应用。 具体操作步骤请参考官网https://developer.huawei.com/consumer/cn/doc/development/quickApp-Guides/quickapp-access-push-kit
通过服务端接口发送:适用面向大批量用户发送,支持推送到现网的快应用和加载器上运行的快应用。服务端接口发送涉及到accessToken接口和发送push消息接口,接口协议格式请参考官网说明。
1)首先访问accessToken接口获取access_token, access_token在发送push消息接口中需要使用到。
2)接着访问发送push消息接口,发送push消息。Push通知栏消息体示例代码截图(js 代码)如下:
Q1:push推送可以不填regid,进行所有用户推送吗?
不可以,推送是根据regid进行的,一个regid代表一个用户。
Q2:AGC上发送Push消息时,填入token后又会消失,如何处理?
填入token后,加上逗号结束即可。
Q3:服务端接口发送时,提示token非法,什么原因呢?
请排查华为申请Push服务使用的包名、签名指纹是否与调试应用中的包名、签名指纹一致。
请排查pushtoken是否是华为快应用引擎返回的token。
Q4: 如何知道推送的消息是否到达用户手机上了呢?
在AGC上开通Push服务时,可填写回执url,回执结果中可以看到华为Push服务返回的推送情况。 例如,Push发送请求结果如下:{“code”:“80000000”,“msg”:“Success”,“request_id”:“159963843932289603004301”}
回执结果如下:{“appid”:“102580573”,“biTag”:“d1c4b1c9cf624bfcb400e76da1446ad6”,“status”:102,“timestamp”:1599638444727,“token”:“AMaY1irGfU2uV2LwcW65m9NgRc9MgMYLA9v_w2s-MhLtxceDiBHVUXXX9ifS2S14mYbvzqsQwLl9NTcF7R-DdBr_33x_V4BzVJFSrLwZjWWYfGz_AGQpWnkzLpeXellUzw”}
请求结果返回成功,但是回执结果状态是102,实际上消息并没有到达手机上,回执结果中“status”:102表明消息被频控了。
欲了解更多详情,请参阅:
快应用开发指导文档:https://developer.huawei.com/consumer/cn/doc/development/quickApp-Guides/quickapp-whitepaper
快应用Push接入:https://developer.huawei.com/consumer/cn/doc/development/quickApp-Guides/quickapp-access-push-kit
原文链接:https://developer.huawei.com/consumer/cn/forum/topicview?tid=0202381629952320300&fid=18 作者:鼓楼赵又廷
华为开发者论坛 安卓开发 华为开发者论坛是一个为开发者提供信息传播、开发交流、技术分享的交流空间。开发者可以在此获取技术干货、华为源码开放、HMS最新活动等信息,欢迎大家来交流分享!