即时通讯技术简介
即时通讯技术(IM)支持用户在线实时交谈。如果要发送一条信息,用户需要打开一个小窗口,以便让用户及其朋友在其中输入信息并让交谈双方都看到交谈的内容.有许多的IM系统,如AOL IM、Yahoo IM、 MSN以及QQ,它们最大的区别在于各自通讯协议的实现,所以即时通讯技术的核心在于它的传输协议。
协议用来说明信息在网络上如何传输,如果有了统一的传输协议,那么应当可以实现各个IM之间的直接通讯,为了创建即时通讯的统一标准,目前已经出现过的IM协议包括:IETF的对话初始协议(SIP)和即时通讯对话初始协议和表示扩展协议(SIMPLE)、应用交换协议(APEX)、显示和即时通讯协议(PRIM)及基于XML且开放的可扩展通讯和表示协议(XMPP)协议(常称为 Jabber 协议).
人们多次努力,试图统一各大主要IM供应商的标准(AOL、Yahoo及 Microsoft),但无一成功,且每一种IM仍然继续使用自己所拥有的协议.
XMPP起源
XMPP是基于XML的协议,用于即时消息(IM)以及在线现场探测。最初,XMPP作为一个框架开发,目标是支持企业环境内的即时消息传递和联机状态应用程序。当时的即时消息传递网络是私有的,不适合企业使用,XMPP前身是Jabber(1998年),是一个开源组织定义的网络即时通信协议。
XMPP是一个分散型通信网络,这意味着,只要网络基础设施允许,任何XMPP用户都可以向其他任何XMPP用户传递消息。多个XMPP服务器也可以通过一个专门的“服务器-服务器”协议相互通信,提供了创建分散型社交网络和协作框架的可能性
尽管XMPP的出现是为了满足“个人-个人”即时消息传递的要求,但它完全不必局限于此任务。
XMPP概述
XMPP是一种基于XML的协议,它继承了在XML环境中灵活的发展性。这表明XMPP是可扩展的。可以通过发送扩展的信息来处理用户的需求,以及在 XMPP的顶端建立如内容发布系统和基于地址的服务等应用程序。而且,XMPP包含了针对服务器端的软件协议,使之能与另一个进行通话,这使得开发者更容易建立客户应用程序或给一个配置好的系统添加功能。XMPP的核心XML流传输协议的定义使得XMPP能够在一个比以往网络通信协议更规范的平台上。借助于XML易于解析和阅读的特性,使得XMPP的协议能够非常漂亮
XMPP的即时通讯扩展应用部分是根据IETF在这之前对即时通讯的一个抽象定义的,与其他业已得到广泛使用的即时通讯协议,诸如AIM,QQ等有功能完整,完善等先进性
XMPP的扩展协议Jingle使得其支持语音和视频,目前iOS尚不支持
XMPP的官方文档时RFC3920
XMPP协议曾经是Google力推的即时通信协议,其代表作品是GTalk
XMPP定义
MPP:The Extensible Messaging and Presence Protocol(可扩展通讯和表示协议)
XMPP可用于服务类实时通讯、表示和需求响应服务中的XML数据元流式传输。XMPP以Jabber协议为基础,而Jabber是即时通讯中常用的开放式协议
XMPP是基于XML的协议,用于即时消息(IM)以及在线现场探测。促进服务器之间的准即时操作。这个协议可能最终允许因特网用户向因特网上的其他任何人发送即时消息,即使其操作系统和浏览器不同.
XMPP的基本结构
XMPP是一个典型的C/S架构,而不是像大多数即时通讯软件一样,使用P2P客户端到客户端的架构,也就是说在大多数情况下,当两个客户端进行通讯时,他们的消息都是通过服务器传递的。采用这种架构,主要是为了简化客户端,将大多数工作放在服务器端进行。
XMPP中定义了三个角色,客户端,服务器,网关。通信能够在这三者的任意两个之间双向发生。
服务器同时承担了客户端信息记录,连接管理和信息的路由功能.
网关承担着与异构即时通信系统的互联互通,异构系统可以包括SMS(短信),MSN,ICQ等
基本的网络形式是单客户端通过TCP/IP连接到单服务器,然后在之上传输XML流.
XMPP工作原理
1:节点连接到服务器
2:服务器利用本地目录系统中的证书对其认证
3:节点指定目标地址,让服务器告知目标状态
4:服务器查找、连接并进行相互认证
5:节点之间进行交互
XMPP工作原理示意图
传输内容
XMPP应用传输的是与即时通讯相关的指令。在以前这些命令要么用二进制的形式发送(比如QQ),要么用纯文本指令加空格加参数加换行符的方式发送(比如MSN)
而XMPP传输的即时通讯指令的逻辑与以往相仿,只是协议的形式变成了XML格式的纯文本。这不但使得解析容易了,人也容易阅读了,方便了开发和查错
而XMPP的核心部分就是一个在网络上分片段发送XML的流协议。这个流协议是XMPP的即时通讯指令的传递基础,也是一个非常重要的可以被进一步利用的网络基础协议。可以说,XMPP用TCP传的是XML流.
XMPP 通信的结构(XMPP——JID)
每个 XMPP客户端用户必须拥有一个全局惟一标识符。基于历史原因,这些标识符称为 Jabber ID或JID。鉴于协议的分布式特征,JID应包含联系用户所需的所有信息,JID的结构类似于电子邮件地址,但不要求 JID同时也是有效的电子邮件收件人。
客户端和服务器节点,被统称为 XMPP实体,都拥有JID。一个有效的JID包括一系列元素:(1)域名(domain identifier);(2)节点(node identifier);(3)源(resource identifier).它的格式是node@domain/resource,resource这个是可选的,resource就是用于区分同一用户不同端登陆。
例如:SomeCorp公司的员工 John Doe可能拥有JID:[email protected],其中somecorp.com是 SomeCorp公司的XMPP服务器的地址,John.Doe是John Doe的用户名。
还可以使用JID连接到其他资源。这允许在一个XMPP实体标识符之外进一步处理拓展
通信类别及公共XML属性
使用XMPP的实时消息传递系统包含三大通信类别:
消息传递,其中数据在有关各方之间传输
联机状态,允许用户广播其在线状态和可用性
信息/查询请求,它允许XMPP实体发起请求并从另一个实体接收响应
以上三种类型的XMPP节都拥有以下公共属性:
from:源XMPP实体的JID
to:目标接收者的JID
id:当前对话的可选标识符
type:节的可选子类型
xml:lang:如果内容是人们可读的,则为消息语言的描述.
基于 XMPP的数据传输发生在一些 XML流上,默认在端口5222上操作。这些 XML流实际上是两个完整的 XML文档,每个文档对应一个通信方向。一旦会话建立,stream元素将打开。这个元素将封装整个通信文档。然后,一些节被注入这个文档的第二层。最后,一旦通信结束,stream元素将关闭,形成一个完整的文档。
XMPP协议的组成
主要的XMPP协议范本及当今应用很广的XMPP扩展:
RFC3920 XMPP:核心。定义了XMPP协议框架下应用的网络架构,引入了XML Stream(XML流)与XML Stanza(XML节),并规定XMPP协议在通信过程中使用的XML标签。使用XML标签从根本上说是协议开放性与扩展性的需要。此外,在通信的安全方面,把TLS安全传输机制与SASL认证机制引入到内核,与XMPP进行无缝的连接,为协议的安全性、可靠性奠定了基础。Core文档还规定了错误的定义及处理、XML的使用规范、JID(Jabber Identifier,Jabber标识符)的定义、命名规范等等。所以这是所有基于XMPP协议的应用都必需支持的文档。
RFC3921:用户成功登陆到服务器之后,发布更新自己的在线好友管理、发送即时聊天消息等业务。所有的这些业务都是通过三种基本的XML节来完成的:IQ Stanza(IQ节), Presence Stanza(Presence节), Message Stanza(Message节)。RFC3921还对阻塞策略进行了定义,定义是多种阻塞方式。可以说,RFC3921是RFC3920的充分补充。两个文档结合起来,就形成了一个基本的即时通信协议平台,在这个平台上可以开发出各种各样的应用。
XEP-0030服务搜索。一个强大的用来测定XMPP网络中的其它实体所支持特性的协议。
XEP-0115实体性能。XEP-0030的一个通过即时出席的定制,可以实时改变交变广告功能。
XEP-0045多人聊天。一组定义参与和管理多用户聊天室的协议,类似于Internet的Relay Chat,具有很高的安全性。
XEP-0096文件传输。定义了从一个XMPP实体到另一个的文件传输。
XEP-0124 HTTP绑定。将XMPP绑定到HTTP而不是TCP,主要用于不能够持久的维持与服务器TCP连接的设备。
XEP-0166 Jingle。规定了多媒体通信协商的整体架构。
XEP-0167 Jingle Audio Content Description Format。定义了从一个XMPP实体到另一个的语音传输过程。
XEP-0176 Jingle ICE(Interactive Connectivity Establishment)Transport。ICE传输机制,文件解决了如何让防火墙或是NAT(Network Address Translation)保护下的实体建立连接的问题。
XEP-0177 Jingle Raw UDP Transport。纯UDP传输机制,文件讲述了如何在没有防火墙且在同一网络下建立连接的。
XEP-0180 Jingle Video Content Description Format。定义了从一个XMPP实体到另一个的视频传输过程。
XEP-0181 Jingle DTMF(Dual Tone Multi-Frequency)。
XEP-0183 Jingle Telepathy Transport Method
XMPP 要点
1. 客户端(C) 和服务器端(S) 通过TCP连接5222端口进行全双工通信.
2. XMPP 信息均包含在 XML streams中.一个XMPP会话, 开始于<stream> 标签, 并结束于</stream>标签.所有其他的信息都位于这俩标签之间.
3. 出于安全目的考虑, 开始<stream>之后, 后续的内容会被适度的使用 Transpor Layer Security (TLS) 协商传输 和强制性的 Simple Authentication 和 Security Layer (SASL) 协商传输。
4. SASL协商完成后, 一个新的 stream 将会被迅速打开, 它将会更加安全和保密.
XMPP的优缺点
优点:开放,标准(XMPP的技术规格已被定义在RFC3920及RFC3921),证实可用,分散,安全,可扩展
缺点:数据负载过重,没有二进制传输
XMPP的传输小结
XMPP是一种类似于HTTP协议的一种数据传输协议,其过程就如同“解包装--〉包装”的过程。只需要理解其接收的类型及返回的类型,便可以很好的利用XMPP来进行数据通讯.
XMPP官方网站——http://xmpp.org