WebSocket 簡介

webSocket建立連接的過程:
瀏覽器先發(fā)送http報文鲜戒,借用了http協(xié)議來完成一部分握手焚虱,這個http報文中有這么一段信息"Upgrade:websocket"堰燎,這是告訴服務(wù)器"你好楣责,我要切換協(xié)議"聚磺。服務(wù)器接收后坯台,回復(fù)一個http報文,告訴瀏覽器"好的咧最,我已經(jīng)切換到websocket協(xié)議了"捂人。從這里以后就不用http報文了,接下來就完全按照websocket協(xié)議進(jìn)行了矢沿。

1. 為什么需要 WebSocket

我們已經(jīng)有了 HTTP 協(xié)議滥搭,為什么還需要另一個協(xié)議?它能帶來什么好處捣鲸?

答案:因為 HTTP 協(xié)議有一個缺陷:通信只能由客戶端發(fā)起瑟匆。這種單向請求的特點,注定了如果服務(wù)器有連續(xù)的狀態(tài)變化栽惶,客戶端要獲知就非常麻煩愁溜。我們只能使用"輪詢":每隔一段時候,就發(fā)出一個詢問外厂,了解服務(wù)器有沒有新的信息冕象。最典型的場景就是聊天室。

2. 簡介

WebSocket 協(xié)議在2008年誕生汁蝶,2011年成為國際標(biāo)準(zhǔn)渐扮。所有瀏覽器都已經(jīng)支持了。

它的最大特點就是掖棉,服務(wù)器可以主動向客戶端推送信息墓律,客戶端也可以主動向服務(wù)器發(fā)送信息,是真正的雙向平等對話幔亥。

其他特點包括:

  • (1)建立在 TCP 協(xié)議之上耻讽,服務(wù)器端的實現(xiàn)比較容易。

  • (2)與 HTTP 協(xié)議有著良好的兼容性帕棉。默認(rèn)端口也是80和443针肥,并且握手階段采用 HTTP 協(xié)議饼记,因此握手時不容易屏蔽,能通過各種 HTTP 代理服務(wù)器祖驱。

  • (3)數(shù)據(jù)格式比較輕量握恳,性能開銷小,通信高效捺僻。

  • (4)可以發(fā)送文本,也可以發(fā)送二進(jìn)制數(shù)據(jù)崇裁。

  • (5)沒有同源限制匕坯,客戶端可以與任意服務(wù)器通信。

  • (6)協(xié)議標(biāo)識符是ws(如果加密拔稳,則為wss)葛峻,服務(wù)器網(wǎng)址就是 URL。

ws://example.com:80/some/path

3. 客戶端的簡單示例

var ws = new WebSocket("wss://echo.websocket.org");

ws.onopen = function(evt) { 
  console.log("Connection open ..."); 
  ws.send("Hello WebSockets!");
};

ws.onmessage = function(evt) {
  console.log( "Received Message: " + evt.data);
  ws.close();
};

ws.onclose = function(evt) {
  console.log("Connection closed.");
};     

4. 客戶端的 API

4.1 WebSocket 構(gòu)造函數(shù)
const ws = new WebSocket('ws://localhost:8080'); 

執(zhí)行上面語句之后巴比,客戶端就會與服務(wù)器進(jìn)行連接术奖。

4.2 webSocket.readyState

readyState屬性返回實例對象的當(dāng)前狀態(tài),共有四種轻绞。

  • CONNECTING:值為0采记,表示正在連接。
  • OPEN:值為1政勃,表示連接成功唧龄,可以通信了。
  • CLOSING:值為2奸远,表示連接正在關(guān)閉既棺。
  • CLOSED:值為3,表示連接已經(jīng)關(guān)閉懒叛,或者打開連接失敗丸冕。

原文:http://www.ruanyifeng.com/blog/2017/05/websocket.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市薛窥,隨后出現(xiàn)的幾起案子胖烛,更是在濱河造成了極大的恐慌,老刑警劉巖拆檬,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洪己,死亡現(xiàn)場離奇詭異,居然都是意外死亡竟贯,警方通過查閱死者的電腦和手機(jī)答捕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屑那,“玉大人拱镐,你說我怎么就攤上這事艘款。” “怎么了沃琅?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵哗咆,是天一觀的道長。 經(jīng)常有香客問我益眉,道長晌柬,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任郭脂,我火速辦了婚禮年碘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘展鸡。我一直安慰自己屿衅,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布莹弊。 她就那樣靜靜地躺著涤久,像睡著了一般。 火紅的嫁衣襯著肌膚如雪忍弛。 梳的紋絲不亂的頭發(fā)上响迂,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天,我揣著相機(jī)與錄音剧罩,去河邊找鬼栓拜。 笑死,一個胖子當(dāng)著我的面吹牛惠昔,可吹牛的內(nèi)容都是我干的幕与。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼镇防,長吁一口氣:“原來是場噩夢啊……” “哼啦鸣!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起来氧,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤诫给,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后啦扬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體中狂,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年扑毡,在試婚紗的時候發(fā)現(xiàn)自己被綠了胃榕。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡瞄摊,死狀恐怖勋又,靈堂內(nèi)的尸體忽然破棺而出苦掘,到底是詐尸還是另有隱情,我是刑警寧澤楔壤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布鹤啡,位于F島的核電站,受9級特大地震影響蹲嚣,放射性物質(zhì)發(fā)生泄漏递瑰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一隙畜、第九天 我趴在偏房一處隱蔽的房頂上張望泣矛。 院中可真熱鬧,春花似錦禾蚕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至几颜,卻和暖如春倍试,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蛋哭。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工县习, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人谆趾。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓躁愿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親沪蓬。 傳聞我的和親對象是個殘疾皇子彤钟,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容