XMPP(二)XML流-概述
XML流 -概述
XMPP,在本质上,是一种XML流技术。当你准备开始和XMPP服务器会话,你打开一个长时间在线的TCP连接,然后和服务器协商一个XML流(服务器也同样也打开一个流,例如在每个方向有一个流)
一旦你和你的服务器建立了一个XML流,你和你的服务器可以通过流交换三个特别的XML片段: < message/>、< presence/>、和< iq/>。这些片段,称为XML节(XML stanzas),是XMPP中有意义的基本单元,而且一旦你已建立一个XML流,你可以通过流发送无限数量的节
一个节可以被认为是通讯的基本单位,类似于一个数据包或在其他网络协议的消息。
有几个因素决定了一个节的意义:
- 节元素名称,有message、presence或iq。每一种节服务器对它们的路由方式不同,并且客户端对它们的处理也不同。
- Type属性的值依赖于实际中的节种类而变化。这个值由收件人来进一步区分每节是如何处理的。
- 子元素,定义了节的有效载荷。有效载荷可能呈现给用户或按照规范定义的有效载荷的命名空间以自动的方式处理。
一、消息 (message)
XMPP的< message/>节是使用基本的”push”方法来从一个地方到另一个地方得到消息。
消息节有五种不同的类型,通过type属性来进行区分:
-
normal
类型为normal的消息和电子邮件消息最相似,因为它们是单个的消息,对应的回应可能会或也可能不会很快到来。
-
chat
类型为chat的消息在两个实体间的实时对话中交换,例如两个朋友之间的即时通讯聊天。
-
groupchat
类型为groupchat的消息在多用户聊天室中交换,和互联网中的中继聊天类似。
-
headline
类型为headline的消息用于发送警示和通告,并不期望有回应(收到headline的客户端不应该让用户回复)。
-
error
如果对于先前发送邮件发生错误,实体检测这个问题将返回一个类型为error的消息。
除了type属性外,消息节还包括一个to和from地址
from地址不由发送客户端提供,而是由发送者的服务器添加邮戳,以避免地址欺骗。
消息也包含有效载荷元素。核心XMPP规格定义了一些非常基本的有效载荷,例如< body/>和< subject/>,被用于人对人的聊天信息。例如,一个简单的消息如下:
<message from="suke@skh.whu.edu.cn"
to="beta@skh.whu.edu.cn"
type="chat">
<body>Who are you?</body>
<subject>Query</subject>
</message>
注意
-
属性的顺序无关紧要(可以按照字母排序来显示属性,也可以以任何顺序出现)。
-
消息(和其他类的节)可以包含在核心XMPP规格中没有定义的有效载荷
二、出席 (presence)
让别人知道你的状态 ,以确定可不可以进行聊天,建立连接
只有通过你授权的人才能看到你是否在线。这个授权被称为出席订阅(presence subscription)。为了让某人看到你的出席,这个人需要向你发送订阅请求,并且你需要批准该请求。一旦你批准了这个订阅,用户将自动地接收到关于你的网络可用性的常规通知。
订阅模型意味着XMPP的<presence/>节本质上是一个简单、专门的发布-订阅方法,通过这种形式,当你在线,然后将状态改为“会议中”或者“午餐中”,然后离线,向你订阅了出席的人将收到更新的出席信息。
例子
<presence from="suke@skh.whu.edu.cn">
<show>xa</show>
<status>down the rabbit hole!</status>
</presence>
三、信息\查询
信息/查询(IQ)节提供了一种用于请求-应答交互和简单工作流的结构,和HTTP中的GET、POST和PUT方法相似
和<message/>节不同,一个IQ节能包含仅有一个有效载荷,用于定义处理的请求或接收人采用的行为.
另外,发送IQ节的实体必须总是接收一个回复(通常由目的接收者或接受者的服务器产生)
请求和应答通过使用id属性跟踪,id属性由请求实体生成,并被包含在应答的实体中。最后,type属性在IQ节中有特定的值:
- get
请求实体信息,例如请求注册一个账户(类似于HTTP GET)。 - set
请求实体提供一些信息或作出一个请求(类似于HTTP POST或PUT)。 - result
应答实体返回get操作的结果(例如一个实体必须提供信息用来注册账户),或者确认一个set请求(类似于一个HTTP200状态码)。 - error
应答实体或一个中间实体,例如XMPP服务器,通知请求实体它不能处理get或set请求(例如,因为请求的格式不正确,请求实体无权执行该操作等)。早期在HTTP中使用的数字错误代码已被可扩展错误条件的XML元素取代。
例子
<iq from="suke@skh.whu.edu.cn"
id="rr82a1z7"
to="skh.whu.edu.cn"
type="get">
<query xmlns="jabber:iq:roster"/>
</iq>
服务器返回请求的列表
<iq from="skh.whu.edu.cn"
id="rr82a1z7"
to="suke@skh.whu.edu.cn"
type="result">
<query xmlns="jabber:iq:roster">
<item jid="suke@skh.whu.edu.cn/>
<item jid="gmz@skh.whu.edu.cn"/>
<item jid="beta@skh.whu.edu.cn"/>
</query>
</iq>
注 : < query xmlns="jabber:iq:roster"/>代表命名空间,具体参考上一个文章 XML。
- IQ-get请求一种特定的信息,例如注册表、配置数据、服务发现信息或联系人列表。
- IQ-set创建、更新或删除一种特定的信息,例如已完成的表单、已更新的配置数据或者向联系人列表添加。