Websocket使用教程

一、WebSocket是什麼

WebSocket為瀏覽器和服務器之間提供了一種新的實時通信協議。與HTTP不同,它允許服務器主動發送數據給客戶端。在使用WebSocket之前,Web開發人員總是使用輪詢技術來實現實時通訊。輪詢技術往往需要在客戶端和服務器之間頻繁發送大量的請求;然而,WebSocket僅需建立一次連接,之後服務器與客戶端之間就可以互相發送數據。WebSocket還支持完整的雙向通信,你可以在客戶端和服務器之間進行實時對話。

二、WebSocket基本用法

要在頁面使用WebSocket,我們要實例化WebSocket對象並通過它與服務器通信。以下是一個最簡單的WebSocket頁面:

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

 ws.onopen = function(event) {
   console.log("Opened");
   ws.send("Hello Server!");
 };

 ws.onmessage = function(event) {
   console.log( "Message received:", event.data );
 };

 ws.onclose = function(event) {
   console.log("Closed");
 };

我們創建一個新的WebSocket,並連接到wss://echo.websocket.org上。在連接到服務器之後,我們發送了消息並偵聽了來自服務器的消息。

三、WebSocket對象的屬性與方法

1、WebSocket.readyState

此屬性返回連接狀態,具有4個可能的值:

  • WebSocket.CONNECTING: 正在連接
  • WebSocket.OPEN: 已連接
  • WebSocket.CLOSING: 正在關閉
  • WebSocket.CLOSED: 已關閉

下面是使用readyState屬性的例子:

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

 if (ws.readyState === WebSocket.OPEN) {
   console.log("Connected!");
 } else {
   console.log("Not Connected!");
 }

2、WebSocket.send()

此方法允許客戶端向服務器發送數據。你可以發送文本、二進制和blob數據。

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

 ws.onopen = function(event) {
   ws.send("Hello Server!");
 };

3、WebSocket.close()

此方法關閉WebSocket連接。

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

 ws.onclose = function(event) {
   console.log("Closed!");
 };
 
 ws.close();

四、服務端的實現

我們通過Node.js的ws模塊來創建WebSocket服務器。ws是一個簡單且易於使用的WebSocket庫,具有很好的性能和廣泛的瀏覽器支持。

 const WebSocket = require('ws');

 const server = new WebSocket.Server({ port: 8080 });

 server.on('connection', function connection(ws) {
   ws.send('Hello! Welcome to our WebSocket server!');

   ws.on('message', function incoming(message) {
     console.log('received: %s', message);
   });

   ws.on('close', function close() {
     console.log('disconnected');
   });
 });

我們創建了WebSocket服務器並監聽8080端口。當連接建立時,我們發送了一條歡迎消息到客戶端,並向控制台輸出收到的所有消息和連接關閉事件。

五、WebSocket安全

WebSocket支持加密的連接(wss)。為了確保連接安全,請使用wss而不是ws協議。可以使用自己的SSL證書來加密連接,也可以使用第三方證書。

以下是使用Node.js創建wss連接的例子:

 const https = require('https');
 const fs = require('fs');
 const WebSocket = require('ws');

 const server = https.createServer({
   cert: fs.readFileSync('/path/to/cert.pem'),
   key: fs.readFileSync('/path/to/key.pem')
 });

 const wss = new WebSocket.Server({ server });

 wss.on('connection', function(ws, req) {
   console.log(`New Connection from ${req.socket.remoteAddress}`);
 });

在此示例中,我們在創建WebSocket服務器之前創建了HTTPS服務器。我們使用SSL證書啟用HTTPS。隨後,我們創建了WebSocket服務器並監聽HTTPS服務器。

原創文章,作者:FBQY,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/136623.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FBQY的頭像FBQY
上一篇 2024-10-04 00:16
下一篇 2024-10-04 00:16

相關推薦

  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變量類型,而是在變量第一次賦值時自動識別該變量的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬盤。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Qt雷達探測教程

    本文主要介紹如何使用Qt開發雷達探測程序,並展示一個簡單的雷達探測示例。 一、環境準備 在開始本教程之前,需要確保你的開發環境已經安裝Qt和Qt Creator。如果沒有安裝,可以…

    編程 2025-04-29
  • 猿編程python免費全套教程400集

    想要學習Python編程嗎?猿編程python免費全套教程400集是一個不錯的選擇!下面我們來詳細了解一下這個教程。 一、課程內容 猿編程python免費全套教程400集包含了從P…

    編程 2025-04-29
  • Python煙花教程

    Python煙花代碼在近年來越來越受到人們的歡迎,因為它可以讓我們在終端里玩煙花,不僅具有視覺美感,還可以通過代碼實現動畫和音效。本教程將詳細介紹Python煙花代碼的實現原理和模…

    編程 2025-04-29
  • 使用Snare服務收集日誌:完整教程

    本教程將介紹如何使用Snare服務收集Windows服務器上的日誌,並將其發送到遠程服務器進行集中管理。 一、安裝和配置Snare 1、下載Snare安裝程序並安裝。 https:…

    編程 2025-04-29
  • Python畫K線教程

    本教程將從以下幾個方面詳細介紹Python畫K線的方法及技巧,包括數據處理、圖表繪製、基本設置等等。 一、數據處理 1、獲取數據 在Python中可以使用Pandas庫獲取K線數據…

    編程 2025-04-28
  • Python語言程序設計教程PDF趙璐百度網盤介紹

    Python語言程序設計教程PDF趙璐百度網盤是一本介紹Python語言編程的入門教材,本文將從以下幾個方面對其進行詳細闡述。 一、Python語言的特點 Python語言屬於解釋…

    編程 2025-04-28

發表回復

登錄後才能評論