的推送真是一大痛点但也推动叻国内一批做第三方服务的厂商。第三方推送做的比较好的有极光、个推、百度、友盟经过比较之后,最后选择了极光推送其实这些苐三方推送之间的差别并不太大,技术上都没问题能不能收到推送,关键还是看前端进程是不是还活着这也是影响推送成功率的关键。从我们App来看Android的成功率一直不高,还不到iOS的五分之一
前面说了,影响推送成功的关键是前端进程是否活着App想要收到推送的话,就要┅直在后台运行还有一些流氓软件,为了长期在后台运行充分利用Android系统的开放性,无所不用其极这也是早期Android给人体验差的一个重要原因。后来Android系统加强了对后台进程的限制尤其是国内的手机厂商,在对付国产软件方面有很高的造诣,甚至有的手机厂商就只给微信開了特权其他软件到后台几分钟就被杀掉或冻结了。这样用户体验是上来了但是对于推送来说,真是雪上加霜
还好,小米、华为推送模式等手机厂商也意识到了这个问题纷纷推出了自家的推送服务。想从根本上解决Android的问题还得依赖这些厂商呀!2017年10月16日,工信部也聯合国内各大厂商和互联网公司发起成立了统一推送联盟,致力于解决Android推送问题统一推送标准,但估计看到成果还需要些时日远水解不了近渴。于是最近抽时间研究了华为推送模式、小米、OPPO、VIVO这几家国内主流厂商的服务。
通过对各家推送服务SDK的研究将分别对每家嘚推送进行分析,最终给出整合意见
感觉华为推送模式推送的文档比较少,可能跟他的功能太简单有关首先需要解释下几个名词:Hms(華为推送模式移动服务),NC(通知中心)通知栏推送:即常规的推送,消息抵达时由NC或者是小米/VIVO/OPPO/等推送服务弹出通知栏。透传:可简單理解为格式自由定义不弹起通知栏的推送,且透传一般情况下需要在APP处于前后台时才能收到
注意,HMS除了支持推送还支持华为推送模式账号登录,华为推送模式支付等功能你可以根据需要自由对接,但因为我们研究的方向问题这里只讲推送部分。其实在此之前還有一个老版本的华为推送模式推送,但SDK升级后老推送就不再支持文档也不见了,且新老推送是不兼容的你只能二选一。
新的华为推送模式推送服务不支持IOS非华为推送模式手机使用华为推送模式推送SDK则需要APP各自建立长链接。在非华为推送模式手机上首次点开APP后SDK会引導用户下载华为推送模式HMS安装,体验比较差所以不建议大家在非华为推送模式手机上使用该SDK,而且个人尝试了下虽然下载安装了HMS,但未能在非华为推送模式手机成功收到token
华为推送模式手机使用官方推送的好处是显而易见的,杀掉APP通知栏依然可以收到通知所有APP共享推送通道,手机更省电但如果想要使用透传功能,就需要手机处于前后台状态另外即便是EMUI的手机,也不是接入了SDK就能接收推送了文档Φ写到只有部分EMUI4.0和4.1的手机,以及5.0之后的手机才能收到NC服务其次,删除token和通知栏消息开关的api
那如何分辨手机是否支持华为推送模式推送呢官方FAQ提供了几个方法,点开“在线帮助”-“常见问题说明”中有具体的EMUI版本及HMS版本的识别方法,这里不再复述
服务端API调用有流控限淛,用户短时间内发送大量的消息会被流控并返回HTTP 503状态码。默认3000条/秒如需要调整,请联系华为推送模式客服并且每次API调用携带的device_token_list最夶为1000个推送量,如果你的推送是群发则不用理会这个限制
查看文档时,请着重看“开发准备”和“客户端开发指南”,两处的文档描述很详细
agent压缩包,这个压缩包其实就是一些华为推送模式的代码可能官方觉得把所有功能都整合到SDK里太大了,就用这种方式希望大家按需解压但个人感觉其实没什么必要。解压后的根目录中有readme文件建议仔细阅读,如果你是windows请点击bat文件,执行后根据提示按需选择即鈳最终把提取出来的java文件放入工程目录里。
在完成开发者账号申请创建APP,集成SDK修改manifest等准备工作后,你就可以尝试推送一条消息给手機了
其实接入推送SDK,我们开发人员关心的无非三件事一是如何获取token/regid,二是通知消息怎么回调三是推送格式怎么写。
首先token方面华为嶊送模式SDK是异步获取,即调用gettoken方法后方法内部最多只返回成功失败的状态码,只有在自定义消息接收器里才能收到token值而我们常用的极咣SDK,则是同步方法:getregid直接返回空或者具体值。这是他们之间的差异
接下来说下华为推送模式推送消息回调,这里有些坑需要注意目湔自定义的接收器,只能接受两个回调信息onEvent和onPushMsg,前者是通知栏消息的回调后者是透传的回调。但通知栏回调在通知消息到达时是无法收到的无论前后台都不行,只有用户点击了携带附加消息的通知onEvent才能触发正常,而透传之前说过了必须在前后台状态才可以,所以洳果大家收不到推送到达的回调不要着急,SDK就是这样设计的
其实接入到这里,感觉华为推送模式这个推送SDK设计的很别扭相信很多开發者是需要收到推送的时候在APP执行一些操作的,但是华为推送模式的推送不支持用户不点击通知栏,即便应用处于前台你也永远不知噵这条推送到达了。所以如果大家用推送到达的回调来处理一些业务逻辑的话建议发送通知栏消息的时候,再叠加一条透传用于业务处悝
而推送格式方面,华为推送模式支持比较有限通知栏推送只能指定打开APP(即首页,大部分APP首页都是闪屏)或者打开特定页面,不夠灵活譬如我们的使用场景是根据接受的推送信息分别跳转至ABC等页面,使用极光就可以自己在receiver里自由处理而华为推送模式只能用两种方式,一是指定通知栏点击动作为打开APP同时对scheme添加附加信息或对推送添加extra,在启动页根据获取到的附加信息进行处理;二是按照scheme协议的格式在我们的app的manifest里每个要跳转的页面都加入scheme,后台推送时候针对发送即可或者将两个思路融合,创建一个透明样式的activity每次推送我们嘟指向该页面,然后再解析附加信息按需跳转即可而且用这种方式的好处是不用在onEvent里处理回调。
小米文档感觉非常详细全面阅读完之後感觉和极光差不多,如果你熟悉极光推送那么小米推送接入的应该会很快,而且原有逻辑部分几乎不需要修改小米推送的优势是,茬MIUI中所有APP共享推送通道APP被杀死也依然能收到通知,除此之外还支持u3d,python等sdk还有花哨的呼吸灯等推送配置。而且小米推送也是支持IOS的所以悝论上,如果你没有使用其他的统计崩溃统计等功能的话完全可以用小米推送替换掉极光,友盟等
因为小米文档十分完善,这里直接從系统判断token获取,回调方式推送格式四方面分析。
判断MIUI直接在文档中心搜索“如何识别小米设备/MIUI系统”即可,官方文档会告诉你答案
消息回调上,onNotificationMessageArrived在推送消息到达时触发onNotificationMessageClicked则在用户点击通知栏时触发,onReceivePassThroughMessage在透传消息到达时触发但是需要注意,透传依然需要APP处于前后囼状态时候才能回调而通知栏消息到达回调,只有APP在前后台才能收到在APP杀死后重启,不再能回调成功
推送格式上,小米除了提供了潒华为推送模式一样的打开APP,打开指定页面(scheme格式)外还有自定义模式,自定义模式就是用户点击通知栏后打不打开页面,打开什麼页面完全由开发者在receiver收到回调后自己处理。
另外小米推送的功能比华为推送模式强大不少,支持分组别名等功能。后台API调用次数按照文档说法目前没有限制,但是如果是针对regid推送每次API调用最多只能携带1000个。
vivo的推送文档是pdf格式需要下载。按照文档vivo推送目前只支持自家rom,而在token获取回调,推送格式上和极光小米也是类似的。
但是对于vivo推送有一些需要注意,--push推送--push接入FAQ中有几个关键点,一个昰目前vivo推送不支持接入金融类服务!二是支持vivo push的vivo 机型特别少对,你没看错vivo自己家的推送服务,就支持那几款手机而已
X21手机,但是我鼡X21A就不支持推送可见这个局限性还挺大。因为找不到符合条件的手机目前只是把代码整合进去了,具体还没进行测试
而且即便大家整合完毕,也需要留意官方文档中描述,VIVO推送是分时段的为了避免打扰用户,目前vivo手机接收的消息为9:00-21:00服务器允许推送时间为9:00-20:00,单推鈈受此时间限制限制时间外的推送将被作废,不再重发所以需要整合的小伙伴要权衡。
oppo推送目前处于公测阶段打开就会提示只对部汾开发者开放,至于如何成为部分受邀开发者需要通过邮件进行申请,但是到哪里申请不知道这里也没有往下进行了。但想到OV(OPPO和VIVO鉯下简称OV)其实是一个老板,而且看VIVO那边的情况差不多也就明白了,OV的推送服务应该是刚开始起步估计只有部分新款手机才能支持,雖然OV手机的用户占比比较高但是能收到推送的新机型比例应该还是很低的。所以目前是否需要接入看大家各自需要
老牌三方推送,极咣SDK也支持各家推送通道进行整合就类似sharedsdk整合分享原理一样,前提是需要分别注册各家大厂的推送账号创建应用。最后按极光的文档配置各种appid,appkey即可但是极光的该功能是收费服务,具体费用需要咨询极光商务而自己整合肯定没有费用问题。
单独接入各家SDK的最终目的还是偠整合在一起按照目前的粗略调查,OV的ROM占比高达45%以上还是很可观的,如果加上华为推送模式小米,四家厂商的ROM会高达85%+整合后的效果会比单纯集成极光好很多。魅族也有推送但是比例低于1%,三星及其它手机则更低所以就没有关注其他的推送。
整合的意义在于提高嶊送到达率更加省电。 由于目前的OV推送服务有很大的不确定性建议不是特别紧急就不用集成了,保持关注即可毕竟随着时间的推移,支持OV推送的手机比例会大幅度增加届时再接入也不迟。
目前整合的大致思路是首先识别ROM依据rom类型分别启动不同SDK(前边已经介绍了各个廠商识别自家ROM的方法),如果无法成功识别或者启动SDK异常则使用极光等三方推送或小米推送作为兜底。
第二是获取不同厂家的token/regid上报给自巳的服务器进行绑定,因为有的厂家是异步有的是同步获取,需要大家视情况自己处理业务逻辑
第三由服务器针对APP上报的信息,使用鈈同厂家的推送API推送信息推送方式和格式上建议统一,即创建一个透明activity统一使用scheme格式并携带附加信息,看起来大概是这个样子:你定義的scheme:你定义的host?action=你定义的action然后在透明的activity里根据action跳转至不同页面,处理完成后及时关闭这个透明界面即可
至此整个SDK集成的分析就结束了,紟后可能会对此文档不定期更新感谢阅读。