跳至內容

XMPP

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書
(重新導向自Jabber
XMPP
國際標準RFC 6120 (Core) (2011)

RFC 6121 (IM & Presence) (2011)
RFC 7622 (Address Format) (2015)
RFC 3922 (CPIM) (2004)

RFC 3923 (Encryption) (2004)
規範發布1999年,​25年前​(1999
使用於即時通訊
官方網站xmpp.org

XMPP(全稱:Extensible Messaging and Presence Protocol,舊名Jabber[1],中文可譯為可延伸訊息和表示協定)是一種以XML為基礎的開放式即時通訊協定,是經由網際網路工程工作小組(IETF)通過的網際網路標準。

歷史

[編輯]
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是最靈活的。

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

特色

[編輯]

優點

[編輯]
開放
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除了可用在即時通訊的應用程式,還能用在網路管理、內容供稿、協同工具、檔案共享、遊戲、遠端系統監控等。
多樣性
用XMPP協定來建造及布署即時應用程式及服務的公司及開放原始碼計劃分布在各種領域;用XMPP技術開發軟體,資源及支援的來源是多樣的,使得使你不會陷於被「綁架」的困境。

缺點

[編輯]
資料負載太重
隨著通常超過70%的XMPP協定的伺服器的資料流量的存在和近60%的被重複轉發,XMPP協定目前擁有一個大型架空中存在的資料提供給多個收件人。新的議定書正在研究,以減輕這一問題。
二進制資料傳輸受限
XMPP傳輸單一的XML檔案,因此要透過XMPP傳輸二進制資料,需先將二進制資料以Base64編碼。但是大量的二進制資料傳輸,較佳的作法是用外部的其他協定傳輸,而以XMPP進行溝通。至於其他二進制資料加密會話(encrypted conversations)或圖形圖示(graphic icons)以嵌入式使用相同的方法。

運作方式

[編輯]

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

一個標準的JID

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

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

使用實例

[編輯]

XMPP 伺服器的高容錯性和低開銷[5]使得許多大公司使用 XMPP 作為其基礎平台來建立私人信使和聊天,以及提供推播通知[6]

實現

[編輯]

XMPP客戶端軟體

[編輯]

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

XMPP伺服器端軟體

[編輯]

參見

[編輯]

注釋

[編輯]
  1. ^ Jabber Inc. - About Us. [2009-09-14]. (原始內容存檔於2007-07-03). 
  2. ^ Jabber Software Foundation Renamed to XMPP Standards Foundation頁面存檔備份,存於網際網路檔案館) 1月16日2007年 - jabber.org頁面存檔備份,存於網際網路檔案館)仍舊被維護
  3. ^ XEP-0025: Jabber HTTP Polling. [2009-09-08]. (原始內容存檔於2020-10-29). 
  4. ^ XEP-0124: Bidirectional-streams Over Synchronous HTTP (BOSH). [2009-09-08]. (原始內容存檔於2021-02-13). 
  5. ^ ejabberd Massive Scalability: 1 Node — 2+ Million Concurrent Users | ProcessOne Blog. [2018-06-22]. (原始內容存檔於2018-06-22). 
  6. ^ Uses of XMPP. [2018-06-22]. (原始內容存檔於2018-06-22). 
  7. ^ ejabberd & Nintendo Switch NPNS | ProcessOne Blog. [2019-06-05]. (原始內容存檔於2019-06-05). 
  8. ^ АНБ использует протокол Jabber для чатов — «Хакер». [2018-06-24]. (原始內容存檔於2018-06-25). 
  9. ^ EU-Parlament empfiehlt Jabber statt WhatsApp und prüft Signal | heise online. [2019-10-19]. (原始內容存檔於2019-10-19). 

外部連結

[編輯]