webSocket 学习

简介: vwebSocket 学习

引子

WebSocket 是一种在单个 TCP 连接上进行全双工通信的网络协议。它是 HTML5 中的一种新特性,能够实现 Web 应用程序和服务器之间的实时通信,比如在线聊天、游戏、数据可视化等。

相较于 HTTP 协议的请求-响应模式,使用 WebSocket 可以建立持久连接,允许服务器主动向客户端推送数据,避免了不必要的轮询请求,提高了实时性和效率。同时,WebSocket 的连接过程也比较简单,可以通过 JavaScript 中的 WebSocket API 进行创建和管理,并且可以和现有的 Web 技术如 HTML、CSS 和 JavaScript 无缝集成。

WebSocket 协议是基于握手协议(Handshake Protocol)的,它在建立连接时使用 HTTP/HTTPS 发送一个初始握手请求,然后服务器响应该请求,建立连接后就可以在连接上进行数据传输了。

总之,WebSocket 提供了一种快速、可靠且灵活的方式,使 Web 应用程序能够实现实时通信,同时也提高了网络性能和用户体验。

场景

  1. 实时性要求较高的应用,比如在线聊天、游戏、数据可视化等;
  2. 需要频繁交换数据的应用,比如在线编辑器、文件管理器等;
  3. 需要推送服务的应用,比如实时数据监控、通知系统等;
  4. 跨平台的应用,比如桌面应用程序、移动应用程序等。

demo 简易聊天 后端nodejs

ndoejs

import ws from 'ws'
const wss = new ws.Server({ port: 8080 })
const state = {
    HEART:1, 
    MESSAGE:2
}
wss.on('connection', (ws) => {
    console.log('连接 nodejs 服务器成功')
    ws.on('message', (message) => {
        console.log('接收到客户端发来的消息: ' + message)
        wss.clients.forEach((client) => {
            client.send(JSON.stringify({state:state.MESSAGE,message:"我是nodejs服务器,我收到你的消息了" + message}))
        })
    })
    let hraetInreval = null;
    //心跳包
    const sendHeart = () => {
        if(ws.readyState === ws.OPEN){
            ws.send(JSON.stringify({state:state.HEART,message:"心跳"}));
        }else{
            clearInterval(hraetInreval);
        }
    }
    hraetInreval = setInterval(sendHeart, 5000);
})
  1. 首先通过 new ws.Server({ port: 8080 }) 创建了一个 WebSocket 服务器,监听在本机的 8080 端口;
  2. wss.on('connection', (ws) => {...}) 的回调函数中,当有新的客户端连接时,会执行一些初始化操作:
  • 输出日志:console.log(‘连接 nodejs 服务器成功’)
  • 监听客户端发送的消息,并在控制台输出接收到的内容:ws.on(‘message’, (message) => {…})
  • 开启一个定时器,每 5 秒向该客户端发送一条心跳消息:setInterval(sendHeart, 5000);
  1. 客户端发送消息后,服务器会将消息广播给所有连接的客户端:wss.clients.forEach((client) => {…})
    state 是一个自定义的对象,包含了 HEART 和 MESSAGE 两个常量,用于标识消息的类型

前端代码

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta http-equiv="X-UA-Compatible" content="IE=edge">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>Document</title>
   <style>
   </style>
</head>
<body>
   <div>
      <ul id="list">
      </ul>
      <input type="text" id="input">
      <button id="send">发送</button>
      <button id="stop">断开</button>
   </div>
   <script>
      //webSocket
      const list = document.querySelector('#list');
      const ws = new WebSocket('ws://localhost:8080');
      ws.addEventListener('open', () => {
         console.log('连接');
      });
      ws.addEventListener('message', (e) => {
         let data = JSON.parse(e.data)
         const li = document.createElement('li');
         if (data.state == 2) {
            li.innerText = data.message;
            list.appendChild(li);
         }
      });
      const btn = document.querySelector('#send');
      const input = document.querySelector('#input');
      const stop = document.querySelector('#stop');
      btn.addEventListener('click', () => {
         if (input.value) {
            ws.send(input.value)
            input.value = ''
         }
      })
      stop.addEventListener('click', () => {
         ws.close()
      })
   </script>
</body>
</html>

在 HTML 中,有一个包含输入框、发送按钮、断开连接按钮和消息列表的 div。其中输入框的 id 为 input,发送按钮的 id 为 send,断开连接按钮的 id 为 stop,消息列表的 id 为 list。

在 JavaScript 中,定义了一个 WebSocket 对象 ws,并通过 ws.addEventListener() 监听其 open 和 message 事件。当 WebSocket 连接成功时,会输出 连接;当接收到服务端返回的消息时,会解析 JSON 字符串并将消息添加到消息列表中。

此外,还监听了发送按钮和断开连接按钮的点击事件,并在点击后调用相应的方法。发送按钮点击事件会检查输入框中是否有文本,如果有则通过 WebSocket 发送消息;断开连接按钮的点击事件会关闭 WebSocket 连接。

目录
相关文章
学习websocket,原来这么简单
学习websocket,原来这么简单
|
30天前
|
网络协议 API 网络安全
Web实时通信的学习之旅:轮询、WebSocket、SSE的区别以及优缺点
Web实时通信的学习之旅:轮询、WebSocket、SSE的区别以及优缺点
137 0
|
30天前
|
网络协议 安全 JavaScript
Web实时通信的学习之旅:WebSocket入门指南及示例演示
Web实时通信的学习之旅:WebSocket入门指南及示例演示
121 0
|
4月前
|
存储 缓存 JavaScript
WebSocket 学习
WebSocket是用于创建低延迟、高效率双向通信的协议,适合实时数据传输如即时通讯和在线游戏。它通过一次性握手建立长期连接,允许服务器主动推送数据。WebSocket API包括WebSocket对象和事件处理程序,如onopen、onmessage、onerror和onclose。示例代码展示了如何创建WebSocket连接、发送和接收消息及处理各种事件。WebSocket服务器通常需要特定的框架支持,如Node.js中的`ws`库。使用WebSocket时,前端和后端都可以监听open、close、error和message事件来管理连接状态和数据交换。
85 8
|
6月前
|
前端开发
t-io websocket的聊天功能学习记录(二)
t-io websocket的聊天功能学习记录(二)
95 0
|
6月前
t-io websocket的聊天功能学习记录(一)
t-io websocket的聊天功能学习记录(一)
106 0
|
前端开发 Python
Flask学习与实战11:WebSocket的使用与简单通信
用这个协议最方便的就是,服务器主动向客户端推送信息。客户端也可以主动向服务器发送信息。属于应用层协议,在握手阶段还是使用了HTTP的协议。
Flask学习与实战11:WebSocket的使用与简单通信
|
移动开发 网络协议 安全
Swoole 学习之基于 Websocket 弹幕的实现
Swoole 学习之基于 Websocket 弹幕的实现
278 0
Swoole 学习之基于 Websocket 弹幕的实现
|
Web App开发 移动开发 JavaScript
python websocket学习使用
前言 今天看了一些资料,记录一下心得。 websocket是html5引入的一个新特性,传统的web应用是通过http协议来提供支持,如果要实时同步传输数据,需要轮询,效率低下 websocket是类似socket通信,web端连接服务器后,握手成功,一直保持连接,可以理解为长连接,这时服务器就可以主动给客户端发送数据,实现数据的自动更新。
4163 0
|
缓存 网络协议 安全
RSocket 学习(二):HTTP VS WebSocket VS RSocket
RSocket 学习(二):HTTP VS WebSocket VS RSocket
487 0
RSocket 学习(二):HTTP VS WebSocket VS RSocket