您的位置:首页 > 移动开发 > IOS开发

IOS平台的几个推送服务的对比

2014-02-26 17:37 309 查看


       最近研究了一下极光推送(JPush),百度云推送和个推在IOS平台的推送机制,做了一下对比。

       首先, 介绍苹果推送通知服务的推送机制(APNS: Apple Push Notification Service):



                                                  图1  APNS的推送流程

上图清晰地展示了APNS整个工作流程,其中Provider是第三方开发者的服务器。整个流程分三个阶段:

第一阶段:应用程序把要发送的消息、目的iPhone的标识打包,发给APNS。
第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发送iPhone。
第三阶段:iPhone把发来的消息传递给相应的App,并且按照设定弹出Push通知。
极光推送(JPush):

      JPush在IOS平台上有完整的推送服务,他整个推送过程完全不依赖APNS的服务,也就是图1中的APNS变成了JPush自己的Push服务器。Iphone到Client App这个过程被简化了,JPush采用的是透传方式,消息的传递对于用户是透明的,不可见的,消息从JPush服务器直接就传到了Client App,用户无法感知。

百度云推送:

      百度云推送是基于APNS的,也就是说他仅仅是APNS的一个代理,他的推送过程如下图:

                      


                                                     图2  百度云推送的推送流程(IOS)

 

 整个过程分为一下几个阶段:
管理控制台或者Server SDK初始化IOS App的证书(分为开发版证书和发行版证书)。
运行在手机上的Push SDK执行推送的初始化动作,将AppKey和DevicesToken上传给云推送服务器,服务器保留。
管理控制台或者Server SDK向云推送服务器发送一条推送指令,服务器接到指令后,将控制台传来的UserId(如果是广播没有UserId),Msg,与服务器保留的DevicesToken和证书一并打包传给APNS服务器。
APNS接到数据后,根据UserId,将消息推送给指定的IPhone设备。

PushSDK 在APNS的编码基础上增加自己服务的初始化和绑定接口代码。

个推

     个推的做法就更简单了,他的整个交互图如下:
      


[align=left]                                                              图3  个推推送交互图(IOS)
[/align]
       他对开发商的要求最高,他的官方论坛上有这么一句话:“开发者首先有一个自己的iOS推送组件,该组件可以实现从你们到苹果服务器的推送,根据我们提供的协议增加相应接口”。图3的右半部分,也就是第三方到APNS这个部分都是由第三方自己实现的,个推仅仅是实现个推服务器与第三方之间的交互。

       图中各个函数的含义:
auth():个推服务器向第三方发送“验证”指令,如果验证结果正确,则第三方返回Token,8个推服务器保留这个Token。
get_tags():个推服务器向第三方发送“获取tag”指令,第三方向个推服务器返回当前存在的tag列表,个推服务器保留。
push_by_tags():个推服务器根据保留的tag列表,可以选择向一些tag发送消息,讲“向tag发送消息”的指令传递给第三方,第三方完成消息发现送任务。
push_by_divece():个推根据divicesId调用第三方发送接口,完成发送任务。

纵观整个流程,个推服务器做的都是一些比较简单的事情,他要求第三方根据他的协议完成auth(),get_tags(),push_by_tags(),push_by_divice()接口,并给出API的地址,供个推服务器调用。笔者认为他这样做的原因是希望能够与android平台的推送共用一套系统,便于管理维护。

2014年2月25日更新:

   笔者今天去个推主页查看的时候发现个推的解决方案换了,个推最近自己提供了到APNS组件,这样第三方开发者就不需要自己实现到APNS的组件服务了,只需要把IOS的证书以及证书密码传给个推即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: