推送原理(一)

推送第三方:友盟、个推、极光、融云、信鸽等

其实原理都是APNS

1.APNS的推送机制

首先我们看一下苹果官方给出的对iOS推送机制的解释。如下图

Provider就是我们自己程序的后台服务器,APNS是Apple Push Notification Service的缩写,也就是苹果的推送服务器。

上图可以分为三个阶段:

第一阶段:应用程序的服务器端把要发送的消息、目的iPhone的标识打包,发给APNS。

第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发送到iPhone。

第三阶段:iPhone把发来的消息传递给相应的应用程序,并且按照设定弹出Push通知。

总结:

自身应用服务器发推送消息到苹果推送服务器,苹果推送服务器再把消息在分发给对应手机。思考:

1.具体工作流程是什么,为什么苹果服务器能把推送到安装过自己app的手机?(看APNS推送通知的详细工作流程

2.为什么不直接通过自身服务器推给对应手机,中间需要苹果服务器这一档子事。(可以看安卓和iOS推送区别对比)


APNS推送通知的详细工作流程

下面这张图是说明APNS推送通知的详细工作流程:

推送原理(一)_第1张图片

根据图片我们可以概括一下:

1、应用程序注册APNS消息推送。

2、ios从APNS Server获取devicetoken,应用程序接收device token。

3、应用程序将device token发送给程序的PUSH服务端程序。

4、服务端程序向APNS服务发送消息。

5、APNS服务将消息发送给iPhone应用程序。

总结:中间的链接点就是devieceToken,保障了苹果服务器最终推送的手机是安装自身app的手机(设备)。它就是在苹果服务器注册一个门户,当自身服务器把消息和token发给苹果服务器,苹果服务器就知道是哪个门户,然后把消息发给这个门户。

举个例子:有个中间传话人(苹果服务器),甲同学(自身服务器),乙同学(安装有自身APP的苹果设备)。

楼上甲同学有封情书想给楼下乙同学,可是害羞不愿出面,于是交给中间传话人,把信和乙同学名字告诉他。中间传话人一想到之前认识乙同学,是因为乙同学把自己的明信片给了中间传话人(通过token),很快中间人就把信交给乙同学。

其实推送只解决的问题是:把信息推送给APP的功能。

打开推送消息就是app和自身服务器的交互,从而使整个推送形成闭环。

安卓和iOS推送原理对比

iOS 系统的推送(APNS,即 Apple Push Notification Service)依托一个或几个系统常驻进程运作,是全局的(接管所有应用的消息推送),所以可看作是独立于应用之外,而且是设备和苹果服务器之间的通讯,而非应用的提供商服务器。你的例子里面,腾讯 QQ 的服务器(Provider)会给苹果公司对应的服务器(APNs)发出通知,然后再中转传送到你的设备(Devices)之上。当你接收到通知,打开应用,才开始从腾讯服务器接收数据,跟你之前看到通知里内容一样,但却是经由两个不同的通道而来。

而 Android,就不同,更像是传统桌面电脑系统做法。每个需要后台推送的应用有各自的单独后台进程,才能和各自的服务器通讯,交换数据。另外其实 Android 也有类似 APNS 的 GCM(Google Cloud Message),属于开发者可选,非强制。(更多请看本回答评论区里面

@Bill Cheng

的补充)

所以你大概看出来区别,iOS 的消息推送机制面世之时是一种全新的解决方案(堪称平台中的平台),应用本身不能有常驻的后台进程,系统的开销少,内存使用更少,电量也更少(把更多的运算和资源开销放在云端,非设备端)。而 Android 的特点,虽然开销大,优点是更稳定快速,但不明显。

这就是为什么多此一举用苹果服务器的原因:应用本身(自己app)不能有常驻的后台进程,系统的开销少,内存使用更少,电量也更少。

准备工作

首先要有一台苹果的设备,模拟器是不支持推送的,所以你需要一台iphone,ipod touch或者ipad。

我们的客户端与苹果服务器之间和我们自己的服务器与苹果服务器之间都需要证书来进行链接。下面我们来开始进入证书的制作

http://blog.csdn.net/yuxiang19876021/article/details/52217187

链接:https://www.zhihu.com/question/20667886/answer/15794992

你可能感兴趣的:(推送原理(一))