XMPP協(xié)議3

XMPP(可擴(kuò)展消息處理現(xiàn)場(chǎng)協(xié)議)是基于可擴(kuò)展標(biāo)記語言(XML)的協(xié)議,它用于即時(shí)消息(IM)以及在線現(xiàn)場(chǎng)探測(cè)。XMPP協(xié)議采用的是客戶端-服務(wù)器架構(gòu),所有從一個(gè)客戶端發(fā)到另一個(gè)客戶端的消息和數(shù)據(jù)都必須經(jīng)過XMPP服務(wù)器轉(zhuǎn)發(fā),而且支持服務(wù)器間DNS的路由,也就是說可以構(gòu)建服務(wù)器集群,XMPP的前身是一個(gè)開源組織制定的網(wǎng)絡(luò)通信協(xié)議——Jabber,XMPP的核心是在網(wǎng)絡(luò)上分片段發(fā)送XML流的協(xié)議,這個(gè)協(xié)議是XMPP的即時(shí)通訊指令的傳遞手段。

?XMPP的基本網(wǎng)絡(luò)結(jié)構(gòu) :

xmpp定義了3個(gè)角色:Client Server Gateway

通信能夠在這三者的任意兩個(gè)之間雙向發(fā)生。

服務(wù)器同時(shí)承擔(dān)了客戶端信息記錄,連接管理和信息的路由功能。

網(wǎng)關(guān)承擔(dān)著與異構(gòu)即時(shí)通信系統(tǒng)的互聯(lián)互通,異構(gòu)系統(tǒng)可以包括SMS(短信),MSN,ICQ等?;镜木W(wǎng)絡(luò)形式是單客戶端通過TCP/IP連接到單服務(wù)器,然后在之上傳輸XML。

?客戶端利用xmpp(基于TCP/IP)訪問server,傳輸?shù)氖荴ML?

Client--------Server----Client

? ? TCP ? ? ? ? ? ? ? TCP ? ? ? ? ? ?TCP

XMPP server:

其內(nèi)核是一個(gè)XMPP路由器,完成基本組件間的數(shù)據(jù)包交換和路由。

功能:

1.會(huì)話管理器:負(fù)責(zé)客戶端會(huì)話認(rèn)證,在線狀態(tài),用戶聯(lián)系表等

2.數(shù)據(jù)存儲(chǔ)器(XDB):連接數(shù)據(jù)庫系統(tǒng),保持用戶信息、通信日志等

3.連接器管理器:管理與客戶端之間的連接

4.服務(wù)器連接器:管理xmpp服務(wù)器之間的連接

5.傳輸器:建立xmpp服務(wù)器與非xmpp服務(wù)器通信

所有從一個(gè)client到另一個(gè)client的jabber消息和數(shù)據(jù)都要通過xmpp server:

1.client連接到server

2.server利用本地目錄系統(tǒng)的證書對(duì)其認(rèn)證

3.client制定目標(biāo)地址,讓server告知目標(biāo)狀態(tài)

4.server查找,連接并進(jìn)行相互認(rèn)證

5.client間進(jìn)行交互

統(tǒng)一的JID(jabber identifier)

JID=[ node”@” ] domain [ “/” resource ]

eg: cyber@cyberobject.com/res

domain:服務(wù)器域名

node: 用戶名

resource:屬于用戶的位置或設(shè)備

一個(gè)用戶可以同時(shí)以多種資源與同一個(gè)XMPP服務(wù)器連接xmpp (手機(jī)和PC)

xml包括3個(gè)元素:

簡(jiǎn)單示例:

<stream>

? ?<presence>

? ? ? ? <status/>


<message>

? ? ?<body/>


</message>

<iq>

<bind/>

</iq>

</stream>

<presence>--此元素確定用戶的狀態(tài)

<presence from = cyber1@jabber.org/contact

to = cyber2@jabber.org/contact>

<status>online</status>

</presence>



<message>-用于兩個(gè)用戶之間發(fā)送信息

<message frome=cyber1@jabber.org/contact

to = cyber2@jabber.org/contact

Type = "chat">

<body>Hello</body>

</message>


<iq>信息/請(qǐng)求,是一個(gè)請(qǐng)求響應(yīng)機(jī)制,管理xmpp服務(wù)器上兩個(gè)用戶的轉(zhuǎn)換,允許他們通過相應(yīng)地xml格式查詢和響應(yīng)

<iq

from = cyber1@jabber.org/contact

id = "id1" Type = "result"

</iq>

Id的主要屬性:type,包括:

Get:獲取當(dāng)前域值

Set:設(shè)置或替換get查詢的值

Result:說明成功地響應(yīng)了先前的查詢

Error:查詢和響應(yīng)中出現(xiàn)的錯(cuò)誤

XMPP 協(xié)議族基于TCP

XMPP采用SASL作為身份認(rèn)證協(xié)議

SASL包含的信息:

<服務(wù)名>:XMPP

<初始序列>

<交換序列>

<安全層協(xié)商>

順序:[TCP]?[TLS]?[SASL]?[XMPP]?

XMPP采用TLS的“START-TLS”擴(kuò)展來為通信雙方提供加密性和數(shù)據(jù)完整性服務(wù)

登錄xmpp服務(wù)器過程示例 :C—client? ? ? S—server

步驟:1.client初始流給server?

?C:<stream:stream to = "example.com" xmlns="jabber:client" xmlns:stream="http://etherx.jabber.org/streams" version = "1.0">

2:server使用一個(gè)流標(biāo)記作為響應(yīng)發(fā)給client


3:Server發(fā)送STARTTLS擴(kuò)展給client,并帶有認(rèn)證機(jī)制與任何其他流特征

4. Client發(fā)送STARTTLS命令給ServerC:

5.Server通知Client它被允許處理 S:Note:client與server TLS協(xié)商失敗,server通知client TLS協(xié)商失敗,并關(guān)閉流與TCP連接

6. 如果TLS協(xié)商成功,client初始化一個(gè)新流給server C:

7.Server靠發(fā)送帶有任何可利用流特征的流頭作為響應(yīng)S:PLAINDIGEST-MD5zlib

8.Client選擇一個(gè)認(rèn)證機(jī)制C:AGh4dwAx

9.Server通知client認(rèn)證成功S:Note:如果認(rèn)證不成功,server通知client認(rèn)證失敗,并關(guān)閉流

10.如果認(rèn)證成功,client初始化一個(gè)新流給serverC:

11.Server依靠流頭來響應(yīng)client,并伴隨有另外的特征S:zlib

12.資源綁定:client發(fā)送一個(gè)類型為set的iq,并包含所需綁定的資源節(jié)點(diǎn)C:spark

13.如果server為client產(chǎn)生了一個(gè)資源標(biāo)識(shí)符或是接受了由客戶端提供的資源標(biāo)識(shí)符,它必須返回一個(gè)類型為result的iq節(jié)點(diǎn)給client,并必須包含子節(jié)點(diǎn),來為server決定的已連接資源指定全JIDS:sparkusername@cyber/spark

14.Client向server請(qǐng)求sessionC:

15.Server告知client,session已建立S:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容