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/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

发表回复

登录后才能评论