使用 WebSocket 进行实时数据传输

以下是使用 WebSocket 进行实时数据传输的一般步骤:

一、前端部分

(一)创建 WebSocket 连接

复制代码
const socket = new WebSocket('ws://your-server-url'); 

在上述代码中,将 'ws://your-server-url' 替换为您实际的服务器 WebSocket 地址。

(二)处理连接打开事件

复制代码
socket.onopen = function(event) {
  console.log('连接已建立');
  // 在此处可以发送初始数据给服务器
  socket.send('Hello, Server!');
};

(三)处理接收数据事件

复制代码
socket.onmessage = function(event) {
  const data = event.data;
  console.log('接收到数据: ' data);
  // 对接收的数据进行处理和展示
};

(四)处理连接关闭事件

复制代码
socket.onclose = function(event) {
  if (event.wasClean) {
    console.log(`连接已关闭,代码: ${event.code},原因: ${event.reason}`);
  } else {
    // 例如连接意外中断
    console.log('连接中断'); 
  }
};

(五)处理错误事件

复制代码
socket.onerror = function(error) {
  console.error('发生错误: ' error.message);
};

二、后端部分(以 Node.js 为例)

(一)安装依赖

复制代码
npm install ws

(二)创建 WebSocket 服务器

复制代码
const WebSocket = require('ws');

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

wss.on('connection', function connection(ws) {
  ws.on('message', function incoming(message) {
    console.log('接收到客户端消息: %s', message);

    // 向客户端发送数据
    ws.send('Hello, Client!');
  });

  ws.on('close', function close() {
    console.log('客户端连接关闭');
  });
});

希望上述内容对您有所帮助,如果您在使用过程中遇到问题,欢迎随时提问。

相关推荐
DashVector1 小时前
DashVector专有网络
网络
vision_wei_2 小时前
Redis中间件(二):Redis协议与异步方式
网络·数据库·c++·redis·分布式·缓存·中间件
Fanmeang2 小时前
VGMP(VRRP Group Management Protocol)VRRP组管理协议
运维·网络·华为·防火墙·vrrp·双机热备·vgmp
天天扭码3 小时前
很全面的前端面试题——计算机网络篇(上)
前端·网络协议·面试
Rverdoser3 小时前
网站、域名、IP在什么场景下需要备案
网络·网络协议·tcp/ip
卑微的小鬼3 小时前
TCP的三次握手和四次挥手实现过程。以及为什么需要三次握手?四次挥手?
网络·网络协议·tcp/ip
CHENKONG_CK3 小时前
晨控CK-GW08S与汇川AC系列PLC配置Ethernet/IP通讯连接手册
网络·网络协议·tcp/ip·射频工程·rfid
Johny_Zhao5 小时前
SeaTunnel的搭建部署以及测试
linux·网络·网络安全·信息安全·kubernetes·云计算·containerd·devops·seatunnel·系统运维
nVisual5 小时前
运维新纪元:告别Excel手工规划,实现“零误差”决策
运维·网络·设计模式·自动化
Codeking__6 小时前
应用层自定义协议与序列化
服务器·网络