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

資訊專欄INFORMATION COLUMN

學習WebSocket(附: WebSocket + koa例子)

0xE7A38A / 504人閱讀

摘要:優(yōu)點參考維基與對比圖客戶端例子連接成功后調用當接收到服務器消息時調用連接關閉后調用服務端例子運行結果客戶端服務端名詞解釋握手一般創(chuàng)建鏈接需要通過瀏覽器發(fā)出請求服務器做出回應這個過程稱為握手參考鏈接協(xié)議分鐘從入門到精通

原文地址
github項目地址

1. 什么是WebSocket?
WebSocket是一種在單個TCP連接上進行全雙工通信的協(xié)議。  
使得客戶端和服務器之間的數據交換變得更加簡單,允許服務端主動向客戶端推送數據。
在WebSocket API中,瀏覽器和服務器只需要完成一次握手,兩者之間就直接可以創(chuàng)建持久性的連接,并進行雙向數據傳輸。
2. 優(yōu)點(參考維基)

WebSocket與HTTP對比圖

客戶端例子
    const ws = new WebSocket("ws://localhost:8888");

    ws.onopen = () => {
        console.log("WebSocket onopen");
    }

    ws.onmessage = e => {
        console.log("WebSocket onmessage");
        console.log("WebSocket message received:", e);
        console.log("WebSocket data received:", e.data);
    }

    ws.onclose = e => {
        console.log("WebSocket onclose");
    };

WebSocket.onopen: 連接成功后調用

WebSocket.onmessage: 當接收到服務器消息時調用

WebSocket.onclose: 連接關閉后調用

服務端例子(koa)
  const Koa = require("koa");
  const WebSocket = require("ws");

  const app = new Koa();
  const ws = new WebSocket.Server({port: 8888});

  ws.on("connection", ws => {
      console.log("server connection");

      ws.on("message", msg => {
        console.log("server receive msg:", msg);
      });

      ws.send("Information from the server");
  });

  app.listen(3000);
運行結果

客戶端

服務端

名詞解釋

握手: 一般創(chuàng)建WebSocket鏈接, 需要通過瀏覽器發(fā)出請求,服務器做出回應, 這個過程稱為“握手”

參考鏈接

WebSocket協(xié)議:5分鐘從入門到精通
MDN

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

轉載請注明本文地址:http://systransis.cn/yun/101841.html

相關文章

  • 服務端事件EventSource揭秘

    摘要:不過永久幀的技術會導致主頁面的加載條始終處于狀態(tài),體驗很差。同時,規(guī)范允許服務端指定自定義事件,客戶端偵聽該事件即可。 服務端推 服務端推,指的是由服務器主動的向客戶端發(fā)送消息(響應)。在應用層的HTTP協(xié)議實現中,請求-響應是一個round trip,它的起點來自客戶端,因此在應用層之上無法實現簡易的服務端推功能。當前解決服務端推送的方案有這幾個: 客戶端長輪訓 websocket...

    sf190404 評論0 收藏0
  • 淺談 WebSocket

    摘要:接口用于接收服務器發(fā)送的事件。因此,是目前來說最佳的選擇。最大特點就是,服務器可以主動向客戶端推送消息,客戶端也可以主動向服務器發(fā)送信息,是一種不受限的全雙工通信。若是,則交給的回調函數處理,否則,還是走正常的回調的路子。 使用 WebSocket 的理由 傳統(tǒng)的http協(xié)議有一個根本性的缺陷,那就是請求只能由客戶端向服務器發(fā)起,服務器接收到請求后再進行響應,把數據返回給客戶端。也就是...

    Jensen 評論0 收藏0

發(fā)表評論

0條評論

0xE7A38A

|高級講師

TA的文章

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