WebSocket解析

来源:http://www.cnblogs.com/unclekeith/archive/2017/12/22/8087182.html
-Advertisement-
Play Games

WebSocket解析 轉載請註明出處: "WebSocket解析" 現在,很多網站為了實現推送技術,所用的技術都是輪詢。輪詢是指在特定的時間間隔(如每一秒),由瀏覽器對伺服器發起HTTP請求,然後由伺服器返回數據給瀏覽器 。由於HTTP協議是惰性的,只有客戶端發起請求,伺服器才會返回數據。輪詢技術 ...


WebSocket協議解析

轉載請註明出處:WebSocket解析

現在,很多網站為了實現推送技術,所用的技術都是輪詢。輪詢是指在特定的時間間隔(如每一秒),由瀏覽器對伺服器發起HTTP請求,然後由伺服器返回數據給瀏覽器
。由於HTTP協議是惰性的,只有客戶端發起請求,伺服器才會返回數據。輪詢技術實現的前提條件同樣是基於這種機制。而WebSocket屬於服務端推送技術,本質是一種應用層協議,可以實現持久連接的全雙工雙向通信。在介紹WebSocket之前,先談談輪詢技術和HTTP流技術。

文章目錄

  • 傳統輪詢技術:Ajax短輪詢
  • Comet
    • Ajax長輪詢
    • HTTP流
  • HTML5實現服務端推送
    • SSE
    • WebSocket

Ajax短輪詢(Ajax Polling)

Ajax短輪詢即客戶端周期性的向伺服器發起HTTP請求,不管伺服器是否真正獲取到數據,都會向客戶端返迴響應。每個request對應一個response,由於HTTP/1.1的持久連接(建立一次TCP連接,發送多個請求)和管線化技術(非同步發送請求),使得HTTP請求可以在建立一次TCP連接之後發起多個非同步請求。

這種傳統的模式帶來很明顯的缺點,即瀏覽器需要不斷的向伺服器發出請求,然而HTTP請求在每次發送時都會帶上很長的請求頭部欄位,其中真正有效的數據可能只是很小的一部分(如Cookie欄位),顯然伺服器會浪費帶寬等資源。

有朋友可能會想,那可以加大Ajax的傳輸時間,如改為3s為一個周期。但是時間長了,對於實時性要求比較高的項目來說,頁面更新的數據也就太慢了。

Comet(服務端推送)

而比較新的技術向伺服器輪詢獲取數據的實現是Comet,即服務端推送。簡單的說,服務端推送就是在客戶端發起HTTP請求之後,伺服器可以主動的向客戶端推送數據。實現Comet的方式有兩種:Ajax長輪詢和HTTP流。

Ajax長輪詢(Ajax Long-polling)

Ajax長輪詢本身不是一個真正的推送。長輪詢是短輪詢的一種變體。在客戶端向伺服器發起HTTP請求之後,伺服器並不是每次都立即響應:當伺服器得到最新數據時,會向客戶端傳輸數據;當數據沒有更新時,伺服器會保持這個連接,等待更新數據之後,才向客戶端傳輸數據。當然,如果服務端數據長時間沒有更新,一段時間後,請求就會超時。客戶端收到超時信息後,會重新發送一個HTTP請求給伺服器。

也就是說,只有在伺服器獲取更新後的數據,才會向客戶端傳輸數據。這種方式也存在弊端。雖然服務端可以主動的向客戶端傳輸數據,但是依然需要反覆發出請求(HTTP請求數量比短輪詢少很多)。

短輪詢和長輪詢的相同點在於客戶端都需要向伺服器發起HTTP請求,不同點在於伺服器如何響應:短輪詢是伺服器立即響應,不管數據是否有效;長輪詢是等待數據更新後響應。

HTTP流

HTTP流不同於輪詢技術,HTTP流只建立一次TCP連接,在3次握手之後進行HTTP通信,此時客戶端向伺服器發起一個HTTP請求,而伺服器保持連接打開,周期性的向客戶端傳輸數據。雙方在沒有明確提出斷開連接時,伺服器就會持續向客戶端傳輸數據。也就是說,假如伺服器數據沒有更新,伺服器不會返迴響應,而是保持連接;如果數據更新了,會立即將數據傳輸給客戶端。此時會發起下一個HTTP請求,過程周而複始。

在JS中,可以通過偵聽readystatechange事件及檢測readyState的值是否為3來實現HTTP流。隨著不斷從伺服器接收數據,readyState的值會周期性的變為3。當readyState值變為3時,responseText屬性就會保存接受到的所有數據。此時,就需要比較此前接收到的數據,決定從什麼位置開始取得最新的數據。用XHR對象實現HTTP流的方式如下:

let httpStream = (url, processor, finished) => {
  let xhr = new XMLHttpRequest()
  let received = 0
  xhr.open(url, 'get', true)
  xhr.addEvetntListener('readystatechange', () => {
    let result
    if (xhr.readyState === 3) {
      result = xhr.responseText.slice(received)
      received += result.length
      processor(result)
    } else if (xhr.readyState === 4) {
      finished(xhr.responseText)
    }
  })
}

只要readyState為3,就對responseText進行分隔以獲取最新數據。這裡的received表示記錄已經處理了多少字元。然後通過processor回調函數來處理最新數據。而當readyState為4時,表示數據已經完全獲取到,則直接將xhr.responseText傳入finished回調函數處理即可。

調用方式如下.

httpStream(url, data => {
  console.log(data)
}, finishedData => {
  console.log(data)
})

對(長、短)輪詢和HTTP流做一個小小的總結

  1. 傳統輪詢技術(Ajax短輪詢)是客戶端向伺服器發起HTTP請求,無論數據是否更新,伺服器都會傳輸數據。一個request對應一個response。
  2. 伺服器推送技術(Ajax長輪詢)是短輪詢的變種,是客戶端向伺服器發起HTTP請求,只有等待數據更新後才會傳輸數據,否則伺服器保持連接狀態。接著發起下一次HTTP請求,一個request對應一個response。
  3. 伺服器推送技術(HTTP流),在客戶端只發起一次HTTP請求,伺服器保持連接狀態,在數據更新之後,伺服器會傳輸數據,否則保持連接狀態。此時一個requset對應多個response。
  4. 無論是短輪詢、長輪詢,還是HTTP流,相同點在於都需要客戶端先發起HTTP請求

HTML5實現服務端推送

由於伺服器推送的重要性(實現賽事結果更新、聊天室等),HTML5實現了兩個服務端推送介面,SSE和WebSocket。

SSE

SSE(Server-Sent Eevents,伺服器發送事件)用於創建到伺服器的單向連接,伺服器通過這個連接可以發送任意數量的數據。實現SSE有以下幾點要求

  1. 伺服器響應的MIME類型必須是text/event-stream。
  2. 必須按照指定的格式輸出。

用法如下,其實理解了伺服器推送之後,SSE使用起來相對簡單

// EventSource接受的參數必須同源。
// 使用message事件監聽從伺服器收到的消息,並存儲在event.data對象里。
let source = new EventSource('index.php')
source.onmessage = e => {
  console.log(e.data)
}

SSE在IE下都不支持,ios4.0以上、android4.4以上都支持SSE。

WebSocket

鋪墊了那麼久的前文,終於到WebSocket了...

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • iOS 記憶體管理 01 一、概述 內部管理簡單來說就是電腦內部存儲的管理,馮·諾依曼結構指出了電腦由運算器、控制器、存儲器、輸入和輸出設備幾大部件組成。我們以 iPhone 8 舉例來說,運算器和控制器合在一起就是 CPU(中央處理器),運行記憶體為 3GB LPDDR4 RAM。而我們平時所說的 ...
  • 一:什麼是BroadcastReceiver Broadcast(廣播)是一種廣泛運用於在應用程式之間一步傳播消息的機制系統消息Android系統發出的,電池不足、來電信息等自定義消息第三方應用發出的廣播消息 廣播消息本質上就是一個Intent對象Intent是一對一的通信,廣播消息是一對多的通信 ...
  • 適用於個人開發者開發的APP中,讓用戶打賞給作者,實質上進行支付寶轉賬到指定賬號的功能。 一、打開‘支付寶’APP ,點擊'收款'功能 ,將收款碼(二維碼)圖片保存到手機上(進一步移到電腦上)。 二、找一個線上二維碼解析網頁工具,解析一下收款碼圖片。將最後一個/後面的字元串複製出來,這是需要使用的部 ...
  • 原由 從事ios工作有段時間了,其中UItableView頻繁被使用中,這個過程中不斷重覆的創建加入代理,好麻煩,而且也讓viewcontroller代碼顯的臃腫,因此做了下麵的封裝 思路 1.減少重覆工作 tableview創建的工作做一次 2.類似的工作作一次 獲取數據過程中就把最後需要多少個s ...
  • 一、首先把橫向的listview的代碼放上來 二、我們來瞭解一下屏幕的觸摸監聽事件的分發機制 Touch事件分發中只有兩個主角:ViewGroup和View。Activity的Touch事件事實上是調用它內部的ViewGroup的Touch事件,可以直接當成ViewGroup處理。 View在Vie ...
  • 一.service的用途 1.1 一種是執行長時間運行的耗時操做 1.如網路下載、音樂播放2.文件系統監控等 1.2 另一種是負責組件間的交互 1.將某些功能以Service組件形式封裝,然後提供給其他組件調用 二.Service的生命周期 Service不能自己啟動,必須由其他應用組件來調用根據調 ...
  • 1. 移動頁面開發基礎 1.1 像素——什麼是像素 像素是 Web 頁面佈局的基礎,那麼到底什麼才是一個像素呢? 像素:一個像素就是電腦屏幕所能顯示一種特定顏色的最小區域。這是像素的概念,實際上,Web 前端開發領域,像素有以下兩層含義: (1) 設備像素:設備屏幕的物理像素,對於任何設備來講物理 ...
  • 通過多次爬坑,發現了這些監聽滾動來載入更多的組件的共同點, 因為這些載入更多的方法是綁定在需要載入更多的內容的元素上的, 所以是進入頁面則直接觸發一次,當監聽到滾動事件之後,繼續載入更多, 所以對於無限滾動載入不需要寫首次載入列表的函數, 代碼如下: html: vue.js data: metho ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...