当前位置: 首页 > article >正文

webSocket的使用文档

webSocket的使用文档

    • 1.webSocket介绍
    • 2.webSocket使用

1.webSocket介绍

WebSocket是在单个TCP连接上提供全双工通信的协议。它允许双方同时进行数据传输,而不需要等待对方的响应,简单说就是他是服务器和客户端相互主动传输信息的约定协议。

优点

  1. 双向通信:WebSocket 允许客户端和服务器之间进行双向通信,客户端可以主动向服务器发送消息,而不需要等待服务器的请求
  2. 低延迟:WebSocket 连接在建立后保持打开状态,减少了每次请求和响应所需的开销,从而降低了延迟。
  3. 持久连接:WebSocket 连接是持久的,允许长时间保持连接而无需重新建立。
  4. 跨域支持:WebSocket 协议支持跨域通信,可以与不同源的服务器进行交互。
    总之,WebSocket 提供了一种高效、灵活的方式来实现实时数据传输,特别适合需要快速和频繁更新数据的应用程序。

2.webSocket使用

webSocker官网介绍

状态:

常量作用
WebSocket.CONNECTING0连接正在建立阶段
WebSocket.OPEN1连接已经建立可以通信
WebSocket.CLOSING2连接正在关闭
WebSocket.CLOSED3连接已经关闭或者未建立连接

代码事例:

javascript
// 初始化 WebSocket 实例,连接到指定的 WebSocket 服务器 (后端地址10.10.10.100:8080)
const webSocket = new WebSocket('ws://10.10.10.100:8080/webSocket');
// 检查WebSocket连接状态 
    if (webSocket.readyState === WebSocket.CONNECTING) {
         console.log("连接正在建立..."); 
    } else if (webSocket.readyState === WebSocket.OPEN) {
        console.log("连接已建立!"); 
    } else if (webSocket.readyState === WebSocket.CLOSING) {
        console.log("连接正在关闭..."); 
    } else if (webSocket.readyState === WebSocket.CLOSED) {
        console.log("连接已关闭!"); 
    }

常用属性:

属性描述
WebSocket.onmessage接收到信息时的回调函数
WebSocket.onopen连接成功后的回调函数
WebSocket.onerror连接失败是要执行的回调函数
WebSocket.onclose设置连接关闭时要执行的回调函数

代码事例:

// 创建 WebSocket 实例,连接到指定的 WebSocket 服务器
const WebSocket = new WebSocket('ws://10.10.10.100:8080/webSocket')
// 连接成功时的回调函数
webSocket.onopen = (event)=>{
    console.log('连接已建立!');  
    // 在这里可以执行连接成功后的操作,例如发送数据
    webSocket.send('Hello, WebSocket Server!');
};

// 接收到消息时的回调函数
webSocket.onmessage = (event)=>{
// 在这里可以处理接收到的消息
    console.log('接收到消息:', event.data);
};

// 连接关闭时的回调函数
webSocket.onclose = (event)=> {
 // 在这里可以执行连接关闭后的操作
   console.log('连接已关闭!');
};

// 连接发生错误时的回调函数
webSocket.onerror = (error)=> {
	//在这里可执行连接失败可重连
    console.error('连接发生错误:', error);
};




http://www.kler.cn/a/394441.html

相关文章:

  • 前端vue 列表中回显并下拉选择修改标签
  • 网络基础Linux
  • 如何向函数模块 FM 中传递 Range 参数
  • Python 中.title()函数和.lower()函数
  • git没有识别出大写字母改成小写重命名的文件目录
  • Bugku CTF_Web——点login咋没反应
  • MySQL【四】
  • 【.GetConnectionTimeoutException的2种情况分析】
  • 打包python代码为exe文件
  • Flutter:Widget生命周期
  • Spring MVC进阶
  • R语言基础| 机器学习
  • 改扩配系列:浪潮英政服务器CS5280H2、IR5280H2——后置SATA、NVME硬盘安装
  • SpringBoot实战:AI大模型+亮数据代理高效获取视频资源
  • 【Apache Paimon】-- 1 -- Apache Paimon 是什么?
  • Python Pandas 结构之 Series 和 DataFrame
  • NFS存储基础操作
  • PostgreSQL 行转列实现
  • 存储大挑战:如何在可靠性与大容量之间玩转平衡术?
  • LabVIEW 使用 Snippet
  • 【Excel】数据透视表分析方法大全
  • 【C++进阶实战】基于linux的天气预报系统
  • CTF攻防世界小白刷题自学笔记15
  • 【Golang】golang框架,为什么选择GoFrame, GoFrame使用心得
  • Electron 项目中杀掉进程的不同方式
  • 《FreeRTOS列表和列表项篇》