热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Androi的消息推送机制

Android消息推送机制研究1.基于HTTP协议的推送机制基于HTTP协议的推送机制是一种请求-响应模式,由于HTTP协议是应用层的单工通信模式,因此它很难实现真正意义上的即时推

Android消息推送机制研究
1.基于HTTP协议的推送机制
基于HTTP协议的推送机制是一种请求-响应模式,由于HTTP协议是应用层的单工通信模式,因此它很难实现真正意义上的即时推送。用HTTP协议实现推送有以下两种方式.
(1)定期轮询:
这种方式是使客户端每隔固定时间向服务器端以post方式发出HTTP请求。在一次请求的开始,客户端询问服务器是否存在需要推送的消息,服务器端收到请求并处理,随后向客户端响应处理结果,这样一次请求就结束了。一段固定时间后,客户端将再次向服务器端发出询问请求并等待服务器端的返回结果。
(2)长轮询:
这种方式是服务器端在接收到客户端向其发出的请求时将请求挂起,直到该连接请求出现异常、超时、或者需要推送消息时再处理该请求,并向客户端返回响应,客户端接收到响应后会立即再向服务器端请求连接。这样就使得服务器与客户端之间的连接始终未中断,比客户端定期轮询的方式具有更好的实时性。
基于HTTP协议的推送机制实际上并不是真正的推送,而是依赖客户端请求-服务器端响应的模式。虽然该机制的实现简单快速且可控性强,但推送具有延迟性,实时性差。另外,虽然其中长轮询形式的推送具有一定的实时性,但是服务器端需要管理大量挂起的请求,会造成服务器端资源消耗,同时由于HTTP协议是无状态的,服务器端不能监控客户端的在线离线状态,因此就不能判断推送的消息能否达到客户端。
2.基于C2DM的推送机制
C2DM (Cloud to Device Messaging)服务是Google公司提供的移动终端消息推送服务。开发者可以将该服务引入自己开发的应用程序中,服务器端推送给客户端的消息是经过C2DM服务器推送的,客户端也可以直接与服务器通信获取信息。其中C2DM服务器类似与推送消息的中间转发者,负责处理用户权限、消息队列等事务并向指定客户端转发由服务器推送的消息。具体使用机制如下图所示。

《Androi的消息推送机制》 Paste_Image.png

(1)客户端首先将应用名和账号发送给C2DM服务器进行注册,注册成功后客户端会收到并存储C2DM返回的注册标识。

(2)客户端向自己的服务器发送该标识和注册成功的账号,使得服务器能使用标识和账号向C2DM请求消息推送。

(3)当服务器需要向客户端发送数据时,获取该客户端注册使用C2DM功能的用户账号的登陆权限。

(4)服务器把要发送的消息、客户端注册标识、账号登陆权限一并发送给C2DM服务器。

(5) C2DM服务器会把收到的消息推送给相应的客户端。

由于其为Google公司提供的原生服务,因此无需实现和部署服务端。然而,正因为其原生性,使其需要用户绑定Google帐号,同时由于该推送机制依赖于Google官方提供的C2DM服务器(服务器在国外),使得该服务在国内不够稳定,常常无法提供服务。另外,国内部分手机厂商,例如中兴、华为等可能会去掉Google的这种原生服务,样推送功能将不能使用。

3.基于MQTT协议的推送机制

MQTT (Message Queuing Telemetry Transport)是由 IBM 在 2001 年发布的轻量级的消息传输协议,支持可发布/可订阅的消息推送模式。协议的轻量级使它十分适合在用在资源受限的环境该协议最初是为物联网设计的,现在也可用来实现消息推送。推送机制的实现主要依靠一个实现了MQTT协议的代理服务器,客户端首先连接代理服务器,然后进行消息订阅,同时,客户端也可向服务器发布消息,其他客户端订阅后也可接收这些消息,因此消息也可在客户端之间传输。该推送机制中代理服务器一般是采用IBM的MQTT服务器RSMB(Really Small Message Broker),客户端一般是采用 IBM 的提供的 wmqtt.jar 包。

MQTT协议是基于代理的“发布/订阅”模式的消息传输协议。由于该协议简洁、小巧、可扩展性强的优点,使得基于该协议的推送机制较省流量和省电,目前已有C++语言编写的服务端组件RSMB。然而由于基于MQTT协议的推送机制实现较复杂,目前这种机制还不够成熟。另外,由于服务器端组件RSMB不开源,也使得在之上的二次开发很困难。

4.基于第三方的推送机制

第三方推送平台有百度云推送、极光推送、_蝶推送、个推等。这些平台是面向个人幵发者或者企业幵发者的,它们一般是按需收费的,能提供多样化的推送。以百度云推送为例,它支持推送文字和富媒体,支持向单用户和群组用广的推送等。开发者开发过程中需要在将第三方平台的SDK集成到客户端,这样,服务器端推送消息吋调用第三方服务器的接口,就可以实现推送消息至客户端。

第三方推送最大的优点是支持多种格式数据的推送和超高并发连接数,然而他们也存在缺陷,例如极光推送使用的自定义的二进制协议,不支持推送信息的加密和身份认证,百度云的加密推送需要额外付费等。另外,采用第三方企业的SDK有程序嵌入的顾虑,存在风险。

5.基于XMPP协议的推送机制

基于XMPP协议的消息推送机制继承了 XMPP协议的优点,具备很强的灵活性和可扩展性,并且将复杂性从客户端转移到服务器端。H前基于该协议己有比较成熟的推送框架,最著名的服务器端推送框架是Openfire,其采用
Java开发,安装、配置和使用都十分容易,并利用Web平台进行管理,基于Openfire能够轻松进行二次开发并实现个性化的推送功能。而客户端框架是
Spark包,它完整的实现了 XMPP协议的幵源API库,同时,为适应
Android运行环境,该包还存在
android平台上的构建版本Spark。另外,H前基于XMPP协议还存在另一个推送机制 Androidpn。它是一个整合方案,其客户端基于Spark,服务器端的实现是基于Openfire,并精简了 Openfire过于繁复庞大的功能,仅仅分离出了消息推送服务。

以Openfire和Spark包构建的基于XMPP协议的推送机制为例,如下图所示,客户端首先和服务器端进行连接,连接后消息可以在服务器端和客户端、客户端和客户端间双向传输。

《Androi的消息推送机制》 Paste_Image.png

基于XMPP协议的推送机制能够实现真正意义上的即时推送,不用像C2DM服务需要担心由于服务器在国外带来的推送服务的不稳定性,也不存在使用第三方的SDK带来的安全风险。同时该机制继承了 XML的优点,具备很强的可扩展性,可以实现复杂的通信。虽然目前基于XMPP协议的推送只支持文字格式的推送,但己满足大部分系统的推送需求,因为一般情况下,推送消息只是告诉客户端服务器端有变化,而变化的具体内容则由客户端主动到服务器获取。目前已有Java语言编写的服务器端与客户端开源程序,使开发者很容易进行二次开发,根据具体需求搭建自己的系统。


推荐阅读
  • 本文总结了一些开发中常见的问题及其解决方案,包括特性过滤器的使用、NuGet程序集版本冲突、线程存储、溢出检查、ThreadPool的最大线程数设置、Redis使用中的问题以及Task.Result和Task.GetAwaiter().GetResult()的区别。 ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • 如何在服务器上配置SSL证书
    SSL证书是用于验证互联网上身份的一种数字凭证,通过启用HTTPS协议,确保用户与服务器之间的通信安全。本文将详细介绍如何在API和服务器上配置SSL证书,以提升网站的安全性和可信度。 ... [详细]
  • IOS Run loop详解
    为什么80%的码农都做不了架构师?转自http:blog.csdn.netztp800201articledetails9240913感谢作者分享Objecti ... [详细]
  • 本文详细介绍了如何使用OpenSSL自建CA证书的步骤,包括准备工作、生成CA证书、生成服务器待签证书以及证书签名等过程。 ... [详细]
  • 河北省工业和信息化厅公文收发管理系统
    河北省工业和信息化厅及其下属各地市工信管理部门之间的文件传输主要依赖于纸质或电子邮件方式,这种方式存在效率低下、安全性差等问题。为了解决这些问题,省工信厅计划开发一套公文收发管理系统,实现文件的电子化和统一管理。 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • 从0到1搭建大数据平台
    从0到1搭建大数据平台 ... [详细]
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
  • 本文深入解析了 Kubernetes 控制平面(特别是 API 服务器)与集群节点之间的通信机制,并对其通信路径进行了详细分类。旨在帮助用户更好地理解和定制其安装配置,从而增强网络安全性,确保集群的稳定运行。 ... [详细]
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 本文是Java并发编程系列的开篇之作,将详细解析Java 1.5及以上版本中提供的并发工具。文章假设读者已经具备同步和易失性关键字的基本知识,重点介绍信号量机制的内部工作原理及其在实际开发中的应用。 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 深入解析CAS机制:全面替代传统锁的底层原理与应用
    本文深入探讨了CAS(Compare-and-Swap)机制,分析了其作为传统锁的替代方案在并发控制中的优势与原理。CAS通过原子操作确保数据的一致性,避免了传统锁带来的性能瓶颈和死锁问题。文章详细解析了CAS的工作机制,并结合实际应用场景,展示了其在高并发环境下的高效性和可靠性。 ... [详细]
  • Swoole加密机制的安全性分析与破解可能性探讨
    本文深入分析了Swoole框架的加密机制,探讨了其在实际应用中的安全性,并评估了潜在的破解可能性。研究结果表明,尽管Swoole的加密算法在大多数情况下能够提供有效的安全保护,但在特定场景下仍存在被攻击的风险。文章还提出了一些改进措施,以增强系统的整体安全性。 ... [详细]
author-avatar
我爱技术交流
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有