成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

websocket資料總結(jié)

android_c / 2596人閱讀

摘要:之前的項目中使用了,趁此機(jī)會將一些知識點及資料進(jìn)行整理總結(jié)。瀏覽器向服務(wù)端發(fā)送一個請求,通過報文頭部來表明需要從切換至協(xié)議。但這樣做的后果就是浪費大量流量,對服務(wù)端造成了巨大壓力。需要注意的是和的前綴表示了和安全協(xié)議的連接。

之前的項目中使用了websocket、socketJS,趁此機(jī)會將一些知識點及資料進(jìn)行整理總結(jié)。正所謂溫故而知新~
本文源地址: http://lsxj615.com/2016/08/14...

websocket是什么

按照慣例,在使用之前,先了解一下概念。

websocket是在html5中提供了一種瀏覽器和服務(wù)器間進(jìn)行全雙工通訊的網(wǎng)絡(luò)技術(shù)。

瀏覽器向服務(wù)端發(fā)送一個請求,通過報文頭部Upgrade來表明需要從HTTP切換至Websocket協(xié)議。

GET ws://echo.websocket.org/?encoding=text HTTP/1.1
Origin: http://websocket.org
Cookie: __utma=99as
Connection: Upgrade
Host: echo.websocket.org
Sec-WebSocket-Key: uRovscZjNol/umbTt5uKmw==
Upgrade: websocket
Sec-WebSocket-Version: 13

如果服務(wù)端理解websocket協(xié)議,它也是通過報文Upgrade從HTTP轉(zhuǎn)換為Websocket協(xié)議。

HTTP/1.1 101 WebSocket Protocol Handshake
Date: Fri, 10 Feb 2012 17:38:18 GMT
Connection: Upgrade
Server: Kaazing Gateway
Upgrade: WebSocket
Access-Control-Allow-Origin: http://websocket.org
Access-Control-Allow-Credentials: true
Sec-WebSocket-Accept: rLHCkw/SKsO9GAH/ZSFhBATDKrU=
Access-Control-Allow-Headers: content-type

這個時候就建立起了websocket連接,基于TCP/IP。使用端口與HTTP(80)和HTTPS(443)一樣。

為什么要用websocket?

知道了什么是websocket,那么為什么要使用websocket呢?除了websocket之外,瀏覽器進(jìn)行即時通信的方式還有以下幾種:

定期查詢
每隔一個時間段就向服務(wù)器發(fā)送一個請求,請求服務(wù)器的最新數(shù)據(jù)再進(jìn)行更新。但這樣做的后果就是浪費大量流量,對服務(wù)端造成了巨大壓力。

Comet
基于http長連接的“服務(wù)器推”技術(shù)??蛻舳伺c服務(wù)器端保持一個長連接,只有客戶端需要的數(shù)據(jù)更新時,服務(wù)器才主動將數(shù)據(jù)推送給客戶端。有兩種形式:

基于Ajax的長輪詢(long-polling)方式
瀏覽器發(fā)出XMLHttpRequest請求,服務(wù)器端接收到請求后,會阻塞請求直到有數(shù)據(jù)或者超時才返回,瀏覽器在處理請求返回信息(超時或有效數(shù)據(jù))后再次發(fā)出請求,重新建立連接。在此期間服務(wù)器端可能已經(jīng)有新的數(shù)據(jù)到達(dá),服務(wù)器會選擇把數(shù)據(jù)保存,直到重新建立連接,瀏覽器會把所有數(shù)據(jù)一次性取回。

基于Iframehtmlfile的流(http streaming)方式
通常的做法是在頁面中嵌入一個隱藏的iframe,然后讓這個iframe的src屬性指向我們請求的一個服務(wù)端地址,并且為了數(shù)據(jù)更新,我們將頁面上數(shù)據(jù)更新操作封裝為一個js函數(shù),將函數(shù)名當(dāng)做參數(shù)傳遞到這個地址當(dāng)中。服務(wù)端收到請求后解析地址取出參數(shù)(客戶端js函數(shù)調(diào)用名),每當(dāng)有數(shù)據(jù)更新的時候,返回對客戶端函數(shù)的調(diào)用,并且將要跟新的數(shù)據(jù)以js函數(shù)的參數(shù)填入到返回內(nèi)容當(dāng)中,例如返回“”這樣一個字符串,意味著以data為參數(shù)調(diào)用客戶端update函數(shù)進(jìn)行客戶端view更新。

當(dāng)應(yīng)用程序有高吞吐量的需求,Comet的長輪詢就不適合了。

SSE
SSE(服務(wù)端推送事件)是一種允許服務(wù)端向客戶端推送新數(shù)據(jù)的HTML5技術(shù)。與websocket相比,WebSocket相較SSE最大的優(yōu)勢在于它是雙向交流的,這意味向服務(wù)端發(fā)送數(shù)據(jù)就像從服務(wù)端接收數(shù)據(jù)一樣簡單。用SSE時,一般通過一個獨立的Ajax請求從客戶端向服務(wù)端傳送數(shù)據(jù)。相對于WebSocket,這樣使用Ajax會增加開銷,但也就多一點點而已。

相比于間斷的輪詢或長輪詢來模擬全雙工連接的解決方式,Websocket極大的減少了不必要的網(wǎng)絡(luò)流量和延遲。除此之外,Websocket-based的應(yīng)用減輕了服務(wù)器的負(fù)擔(dān),讓現(xiàn)有的機(jī)器能支持更多的并發(fā)連接。如下圖所示:

如何使用websocket

【以下例子來源于http://www.websocket.org/abou...】
只需要創(chuàng)建一個新的Websocket實例,提供一個URL,這個URL表示的是你希望連接的那個end-point。如下所示。
需要注意的是: ws://wss://的前綴表示了Websokcet和安全協(xié)議的Websocket連接。

var myWebsocket = new Websocket("ws://www.websocket.org");

在連接到一個端點發(fā)送消息之前,你可以將一系列的事件監(jiān)聽器來處理連接的生命周期的每個階段。如下所示:

myWebSocket.onopen = function(evt) { 
    alert("Connection open ..."); 
};
myWebSocket.onmessage = function(evt) { 
    alert( "Received Message: " + evt.data); 
};
myWebSocket.onclose = function(evt) { 
    alert("Connection closed."); 
};

向服務(wù)端發(fā)送信息,只需要簡單的send并提供你希望傳遞的內(nèi)容。發(fā)送信息后,close終止連接。如下所示:

myWebSocket.send("Hello WebSockets!");
myWebSocket.close();
socketJS

我們都知道,webscoket是HTML5的新玩意,那么兼容性方面,如下圖所示:

可以看出IE8以及Android 4.3是不支持的。這個時候,我們就可以來看看socketJS的優(yōu)勢了。

SockJS is a browser JavaScript library that provides a WebSocket-like object. SockJS gives you a coherent, cross-browser, Javascript API which creates a low latency, full duplex, cross-domain communication channel between the browser and the web server.

socketJS的一大好處在于提供了瀏覽器兼容性。優(yōu)先使用原生websocket,如果在不支持websocket的瀏覽器中,會自動降為輪詢的方式。
除此之外,spring也對socketJS提供了支持。如果代碼中添加了withSockJS()如下,服務(wù)器也會自動降級為輪詢。

registry.addEndpoint("/coordination").withSockJS();  
如何使用socketJS


var sock = new SockJS("/coordination");  
sock.onopen = function() {
    console.log("open");
};
sock.onmessage = function(e) {
    console.log("message", e.data);
};
sock.onclose = function() {
    console.log("close");
};
sock.send("test");
sock.close();

更多內(nèi)容,可查看github地址:https://github.com/sockjs/soc...

什么是Stomp

通過以上部分我們可以知道websocket的優(yōu)勢,兼容性的問題socketJS也幫我們解決了。不過這個時候,我還要安利一個好東西,也就是Stomp。

STOMP is a simple text-orientated messaging protocol. It defines an interoperable wire format so that any of the available STOMP clients can communicate with any STOMP message broker to provide easy and widespread messaging interoperability among languages and platforms (the STOMP web site has a list of STOMP client and server implementations.

具體內(nèi)容,可查看官網(wǎng):http://jmesnil.net/stomp-webs...。或者等我下一篇文章詳談吧~

參考資料:

Spring WebSocket教程(一)

WebSocket詳解(一):初步認(rèn)識WebSocket技術(shù)

STOMP Over WebSocket

sockjs/sockjs-client

Spring websocket 使用

Web端即時通訊技術(shù)盤點:短輪詢、Comet、Websocket、SSE

websocket官網(wǎng)About HTML5 WebSocket

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87850.html

相關(guān)文章

  • 計算機(jī)常識 - 收藏集 - 掘金

    摘要:使用簡記后端掘金全稱為即消息隊列。優(yōu)測優(yōu)社區(qū)干貨精選老司機(jī)亂談編輯器之神掘金前言是一種信仰,我自從年有了這個信仰,已經(jīng)個年頭了。 PHP 程序員進(jìn)階學(xué)習(xí)書籍參考指南 - 后端 - 掘金PHP程序員進(jìn)階學(xué)習(xí)書籍參考指南 @heiyeluren lastmodify: 2016/2/18 ... 當(dāng)我們在談?wù)撉岸思用軙r,我們在談些什么 - 前端 - 掘金潘建旭,豈安科技(www.bigse...

    Yi_Zhi_Yu 評論0 收藏0
  • WebSocket系列之基礎(chǔ)知識入門篇

    摘要:概述本文是系列的第一篇,主要介紹相關(guān)的基礎(chǔ)協(xié)議知識和。客戶端收到響應(yīng)后,立即發(fā)起下一次的請求。收到消息通過事件來接收消息。類型則需要傳遞一個對象作為參數(shù),相關(guān)的內(nèi)容也將在本系列第二篇中進(jìn)行介紹。 概述 本文是WebSocket系列的第一篇,主要介紹WebSocket相關(guān)的基礎(chǔ)協(xié)議知識和API。由于WebSocket的相關(guān)介紹在MDN中分布較亂,初學(xué)者不太容易入門,因此通過本文將相關(guān)基礎(chǔ)...

    Yuqi 評論0 收藏0
  • 即時通信相關(guān)技術(shù)總結(jié)

    摘要:解決問題即時通信要解決三方面的問題雙全工通信低延時支持跨域各種即時通信技術(shù)輪詢客戶端定時向服務(wù)器發(fā)送請求,服務(wù)器接到請求后馬上返回響應(yīng)信息并關(guān)閉連接。優(yōu)點實現(xiàn)真正的即時通信,而不是偽即時。 解決問題 即時通信要解決三方面的問題: 雙全工通信 低延時 支持跨域 各種即時通信技術(shù) 輪詢 客戶端定時向服務(wù)器發(fā)送Ajax請求,服務(wù)器接到請求后馬上返回響應(yīng)信息并關(guān)閉連接。優(yōu)點:后端程序編寫比...

    reclay 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<