本頁使用了標題或全文手工轉換

XMPP

維基百科,自由的百科全書
前往: 導覽搜尋

XMPPExtensible Messaging and Presence Protocol,前稱Jabber[1])是一種以XML為基礎的開放式即時通訊協定,是經由網際網路工程工作小組(IETF)通過的網際網路標準。XMPP因為被Google Talk應用而被廣大網友所接觸。

歷史[編輯]

Jabber
 
XMPP

Jeremie Miller於1998年開始了這個專案。第一個公開版本於2000年5月發行。這個專案的主要產品是jabberd,XMPP的伺服器端軟體。它既可以建立私人的XMPP網路,也可以加入全球的公共XMPP網路。XMPP的關鍵特色是,分散式的即時通訊系統,以及使用XML串流。

Jabber已經由IETF XMPP協定(RFC3920)標準化。

Jabber是一個開放原始碼形式組織產生的網路即時通訊協議。XMPP原本是為即時通訊而量身定製,但由於XML Stanza本身是XML元素,在基於XML靈活發展的特性下,使得XMPP也可以適用其他方面,已經得到了IETF的批准。XMPP與IMPPPRIMSIPSIMPLE)合稱四大IM協議主流,在此4大協定中,XMPP是最靈活的。

2005年,Google發布了Google Talk,這是一個IP電話及即時通訊的服務,即時通訊功能採用了開放的XMPP。預計這將對XMPP社群起很大的推動作用。初期此服務不支援伺服器到伺服器的通訊功能,所以未能完全發揮XMPP的分散式特色;雖然任何XMPP客戶端都能連接到Google Talk,但是用戶若欲登入Google Talk,必須擁有Google Talk帳號(即Gmail帳號),而用戶也無法與公共XMPP網路的用戶對談。自2006年1月17日起,伺服器到伺服器的通訊啟用了,Google Talk用戶可與其他XMPP公共網路的用戶對談。2013年5月,Google Talk升級為Hangouts,不再支援伺服器到伺服器的通訊。[2]

2007年,2001年成立的Jabber軟體基金會更名為XMPP標準基金會[3]

特色[編輯]

優點[編輯]

開放
XMPP協議是自由、開放、公開的,並且易於瞭解。而且在客戶端伺服器元件源碼庫等方面,都已經各自有多種實作。
標準
網際網路工程工作小組(IETF)已經將Jabber的核心XML串流協定以XMPP之名,正式列為認可的即時通訊及Presence技術。而XMPP的技術規格已被定義在RFC 3920及RFC 3921。任何IM供應商在遵循XMPP協定下,都可與Google Talk實現連線。
證實可用
第一個Jabber(現在XMPP)技術是Jeremie Miller在1998年開發的,現在已經相當穩定;數以百計的開發者為XMPP技術而努力。今日的網際網路上有數以萬計的XMPP伺服器運作著,並有數以百萬計的人們使用XMPP即時傳訊軟體。
分散式
XMPP網路的架構和電子郵件十分相像;XMPP核心協定通訊方式是先建立一個stream,XMPP以TCP傳遞XML資料流,沒有中央主伺服器。任何人都可以運行自己的XMPP伺服器,使個人及組織能夠掌控他們的即時傳訊體驗。
安全
任何XMPP協議的伺服器可以獨立於公眾XMPP網路(例如在企業內部網路中),而使用SASLTLS等技術的可靠安全性,已內建於核心XMPP技術規格中。
可擴展
XML命名空間的威力可使任何人在核心協定的基礎上建造客製化的功能;為了維持通透性,常見的擴充套件由XMPP標準基金會英語XMPP Standards Foundation
彈性佳
XMPP除了可用在即時通訊的應用程式,還能用在網路管理、內容供稿、協同工具、檔案共享、遊戲、遠端系統監控等。
多樣性
用XMPP協定來建造及布署即時應用程式及服務的公司及開放原始碼計劃分布在各種領域;用XMPP技術開發軟體,資源及支援的來源是多樣的,使得使你不會陷於被「綁架」的困境。

缺點[編輯]

資料負載太重 
隨著通常超過70%的XMPP協議的伺服器的資料流量的存在和近60%的被重複轉發,XMPP協議目前擁有一個大型架空中存在的資料提供給多個收件人。新的議定書正在研究,以減輕這一問題。
沒有二進制資料 
XMPP協議的方式被編碼為一個單一的長的XML檔案,因此無法提供修改二進制資料。因此, 檔案傳輸協議一樣使用外部的HTTP。如果不可避免,XMPP協議還提供了帶編碼的檔案傳輸的所有資料使用的Base64。至於其他二進制資料加密會話(encrypted conversations)或圖形圖標(graphic icons)以嵌入式使用相同的方法。

運作方式[編輯]

XMPP網路是基於伺服器的(即客戶端之間彼此不直接交談),但是也是分散式的。不像AOL即時通或MSN Messenger等服務,XMPP沒有中央官方伺服器。Jabber.org的公眾伺服器上有大量的用戶,所以有些人誤解了,以為它是官方伺服器,不過事實上任何人都可以在自己的網域上運行XMPP伺服器。

Jabber識別符(JID)是用戶登入時所使用的帳號,看起來通常像一個電子郵件位址,如someone@example.com;前半部分為使用者名稱,後半部分為XMPP伺服器域名,兩個欄位以@符號區隔。

假設朱麗葉(juliet@capulet.com)想和羅密歐(romeo@montague.net)通話,他們兩人的帳號分別在Capulet.com及Montague.net的伺服器上。當朱麗葉輸入訊息並按下傳送鈕之後,一連串的事件就發生了:

  1. 朱麗葉的XMPP客戶端將她的訊息傳送到Capulet.com XMPP伺服器。
  2. Capulet.com XMPP伺服器開啟與Montague.net XMPP伺服器的連接。
  3. Montague.net XMPP伺服器將訊息寄送給羅密歐。如果他目前不在線上,那麼儲存訊息以待稍後寄送。
Juliet
Capulet.com
Montague.net
Romeo

羅密歐與朱麗葉兩人的XMPP服務是由兩家不同的業者所提供的,而他們彼此傳訊時,不須擁有對方伺服器的帳號,也不須成為對方業者的會員。

與其他協議互聯[編輯]

各IM之間的互傳

XMPP協議的另一功能是運輸(transports),也被稱為網關(gateways),可允許用戶透過網路使用其它協議。這可以是其他的即時通訊協議,也可以是不同協議,如簡訊(SMS)或電子郵件。

XMPP協議通過HTTP運輸[編輯]

在原來的規格,XMPP協議可以使用HTTP的方式有兩種:輪詢(polling)[4]與綁定(binding)[5]。輪詢現在不推薦,基本上,輪詢意味著HTTP郵件存儲在伺服器端的資料庫上,客戶端必須一再地以HTTP的GET和POST的方式去抓取(以及刊出)其中的訊息。然而使用綁定的方式時,客戶端會保留一個長存的HTTP連線,等待一旦伺服器有新的訊息時,就立刻接收訊息。因為輪詢的結果往往是伺服端沒有新訊息,這種推播的通知模式比輪詢的方式更有效率。

由於客戶端使用HTTP,大多數防火牆允許客戶端獲取和留言沒有任何障礙。因此,即使使用XMPP協議的TCP埠被攔截,伺服器也能正常地傾聽一般的HTTP埠,其上的訊息也能保持暢通。還有一些網站更允許大眾經由瀏覽器登入進XMPP。尤有甚者,還有一些公共的伺服器同時擁有標準HTTP(80埠)和HTTPS(443埠),因此又有助於通過防火牆。

實現[編輯]

XMPP用戶端軟體[編輯]

XMPP協議是由大量的XMPP協議的客戶端,伺服器和程式庫。主要的文章包含了幾個XMPP協議清單客戶的多種平台。

XMPP伺服器端軟體[編輯]

使用XMPP協定的用戶端與伺服器端對話的例子[編輯]

用戶端(kuusipuu)連線到一個XMPP伺服器(amessage.de:5222/TCP),傳送一條訊息(主題和內容均為「test 1449」)到另一個用戶端(tero),然後登出。

kuusipuu:

<?xml version="1.0"?>
<stream:stream xmlns:stream="http://etherx.jabber.org/streams"
xmlns="jabber:client" to="amessage.de">

amessage.de:

<stream:stream xmlns='jabber:client'
xmlns:stream='http://etherx.jabber.org/streams'
from='amessage.de' id='1461777714'>

kuusipuu:

<iq type="set" id="auth_2" to="amessage.de" >
<query xmlns="jabber:iq:auth">
  <username>kuusipuu</username>
  <password>mypassword</password>
  <resource>Work</resource>
 </query>
</iq>

amessage.de:

<iq from="amessage.de" id='auth_2' type='result'/>

kuusipuu:

<message to="tero@example.com" >
<subject>test 1449</subject>
<body>test 1449</body>
</message>
<presence type="unavailable" >
<status>Logged out</status>
</presence>
</stream:stream>

amessage.de:

</stream:stream>

參見[編輯]

注釋[編輯]

外部連結[編輯]