WebSocket 入门教程

news2025/1/11 5:44:28

什么是 WebSocket?

WebSocket 是一种通信协议,它在单个 TCP 连接上提供全双工通信。与传统的 HTTP 不同,WebSocket 允许服务器主动向客户端推送数据,而不仅仅是客户端请求数据。这使得 WebSocket 非常适用于需要低延迟和实时通信的应用,例如在线聊天、游戏和实时数据流。
在这里插入图片描述

WebSocket 的工作原理

WebSocket 的通信过程可以分为以下几个步骤:

  1. 握手:客户端向服务器发送一个 HTTP 请求,要求升级到 WebSocket 协议。
  2. 建立连接:服务器接受请求并返回响应,连接建立后,客户端和服务器可以在同一连接上互相发送消息。
  3. 传输数据:数据传输过程中,客户端和服务器可以随时发送和接收消息,通信是全双工的。
  4. 关闭连接:任意一方可以随时关闭连接。

WebSocket 的优势

  • 实时性:WebSocket 提供低延迟的实时通信,适用于需要即时响应的应用。
  • 节省带宽:相比 HTTP 轮询,WebSocket 减少了不必要的网络开销,节省带宽。
  • 全双工通信:允许客户端和服务器同时发送和接收数据,通信效率更高。

WebSocket 示例

为了更好地理解 WebSocket 的工作原理,我们将通过一个简单的示例来展示如何使用 WebSocket 进行通信。我们将实现一个基本的 WebSocket 服务器和客户端。

安装 WebSocket 库

在开始之前,我们需要安装 Python 的 websockets 库。可以通过以下命令安装:

pip install websockets
实现 WebSocket 服务器

首先,我们来实现一个简单的 WebSocket 服务器。服务器将接受客户端的连接,并能够接收和发送消息。

# server.py
import asyncio
import websockets

async def handle_connection(websocket, path):
    print("客户端已连接")
    try:
        while True:
            message = await websocket.recv()
            print(f"收到消息: {message}")
            response = f"服务器收到: {message}"
            await websocket.send(response)
            print(f"发送消息: {response}")
    except websockets.ConnectionClosed:
        print("客户端已断开连接")

async def start_server():
    server = await websockets.serve(handle_connection, "localhost", 8765)
    print("WebSocket 服务器已启动,监听端口 8765")
    await server.wait_closed()

if __name__ == "__main__":
    asyncio.run(start_server())
实现 WebSocket 客户端

接下来,我们来实现一个简单的 WebSocket 客户端。客户端将连接到服务器,并发送和接收消息。

# client.py
import asyncio
import websockets

async def communicate():
    uri = "ws://localhost:8765"
    async with websockets.connect(uri) as websocket:
        print("已连接到服务器")
        while True:
            message = input("请输入要发送的消息: ")
            await websocket.send(message)
            print(f"发送消息: {message}")
            response = await websocket.recv()
            print(f"收到消息: {response}")

if __name__ == "__main__":
    asyncio.run(communicate())
运行示例
  1. 启动 WebSocket 服务器:
python server.py
  1. 启动 WebSocket 客户端:
python client.py
  1. 在客户端输入消息,观察服务器端和客户端的消息交互。

WebSocket 的实际应用场景

WebSocket 在许多实时应用中都有广泛的应用。以下是一些常见的使用场景:

  1. 在线聊天应用:例如微信、QQ 等,用户之间需要实时发送和接收消息。
  2. 在线游戏:多人在线游戏需要实时同步玩家的操作和游戏状态。
  3. 实时数据流:例如股票行情、天气预报等,需要实时更新的数据流。
  4. 协作编辑工具:例如 Google Docs,多人实时协作编辑文档。

总结

WebSocket 是一种强大的通信协议,适用于需要低延迟和实时通信的应用。通过本教程的示例代码,我们可以轻松理解 WebSocket 的基本概念和使用方法。

在实际开发中,WebSocket 可以与其他技术结合使用,例如前端的 WebSocket API、服务器端的框架(如 Node.js、Django Channels 等),以构建更复杂和高效的实时应用。

希望本教程能帮助你快速入门 WebSocket,并将其应用到实际项目中。如果你有任何问题或建议,欢迎留言讨论!

参考资料

  • WebSocket 规范
  • Python websockets 库文档

扩展阅读

  • 使用 WebSocket 构建实时应用
  • Node.js 与 WebSocket
  • Django Channels 入门教程

通过以上内容,你应该对 WebSocket 有了一个基本的了解,并能够开始使用 WebSocket 构建自己的实时通信应用。祝你学习愉快!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1828348.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【星座运势】本周财运分析,巨蟹座财富潜力大开!

大家好!今天我们来谈谈巨蟹座本周的财富运势。经过调查和数据分析,我发现巨蟹座这周的财运潜力很大!接下来,我将用通俗易懂的语言,通过代码说明,向大家展示巨蟹座的财富运势。 首先,我们需要通…

通俗范畴论2 有向图与准范畴

退一步海阔天空,在正式进入范畴论之前,我们可以重新审视一下我们是如何认识世界的,有了这个对人类认识世界过程的底层理解,可以帮助我们更好地理解范畴论。 对于人类认识世界,最神奇的一点就是这个世界居然是可以认识…

【SpringBoot】SpringBoot:实现文件上传和下载功能

文章目录 引言项目初始化添加依赖 配置文件存储位置实现文件上传功能创建文件上传控制器创建上传页面 实现文件下载功能创建文件下载控制器 安全性和最佳实践文件大小限制文件类型验证文件名和路径验证文件下载时的安全性 测试与部署示例:编写单元测试 部署结论 引言…

C++的异常捕获

目录 C语言的异常处理方式 C的异常处理方式 异常的抛出与捕获 抛出与捕获原则 自定义异常体系 异常安全 异常规范 异常的优缺点 优点 缺点 C语言的异常处理方式 1、终止程序 常见形式:assert 缺陷:太过强硬,如果发生内存错误&#…

文心一言 VS 讯飞星火 VS chatgpt (282)-- 算法导论20.4 3题

三、在 CONNECTED-COMPONENTS 作用于一个有 k 个连通分量的无向图 G(V,E) 的过程中,FIND-SET 需要调用多少次? UNION 需要调用多少次?用 |V| 、 |E| 和 k 来表示你的答案。如果要写代码,请用go语言。 文心一言&#x…

【Java】过滤器/拦截器

文章目录 两者区别request链路全过程 在实际开发中,过滤器和拦截器都是经常使用的技术,但一被提及到其区别时,整个人就愣住了,好像没有认真地对两者进行区别和总结,这两者之间也确实很容易混淆,因此结合了很…

C++ 54 之 继承中同名的静态成员处理

#include <iostream> using namespace std;// 父类 class Base07{ public:static int m_a; // 静态成员&#xff0c;类内定义static void fun(){cout << "Base中的fun"<< endl;}static void fun(int a){cout << "Base中的fun(int a)&qu…

53. QT插件开发--插件(动态库so)的调用与加载

1. 说明 在使用QT进行插件库的开发之后,还需要将这个插件库程序生成的so动态链接库加载到主程序框架中进行使用,才能达到主程序的模块化开发的效果。在前一篇文章插件创建中介绍了如何在QT中开发插件库,并提供外部接口调用。本篇博客的主要作用是模拟在主程序框架中加载动态…

EasyRecovery2024数据恢复神器#电脑必备良品

EasyRecovery数据恢复软件&#xff0c;让你的数据重见天日&#xff01; 大家好&#xff01;今天我要给大家种草一个非常实用的软件——EasyRecovery数据恢复软件&#xff01;你是不是也曾经遇到过不小心删除了重要的文件&#xff0c;或者电脑突然崩溃导致数据丢失的尴尬情况呢&…

element-ui input输入框和多行文字输入框字体不一样

页面中未作样式修改&#xff0c;但是在项目中使用element-ui input输入框和多行文字输入框字体不一样&#xff0c;如下图所示&#xff1a; 这是因为字体不一致引起的&#xff0c;如果想要为Element UI的输入框设置特定的字体&#xff0c;你可以在你的样式表中添加以下CSS代码…

快速UDP网络连接之QUIC协议介绍

文章目录 一、QUIC协议历史1.1 问题&#xff1a;QUIC为什么在应用层实现1.2 QUIC协议相关术语1.3 QUIC和TCP对比1.4 QUIC报文格式1.4.1 QUIC报文格式-Stream帧11.4.2 QUIC报文格式-Stream帧2 二、QUIC的特点2.1 连接建立低时延&#xff0c;2.2 多路复用流复用-HTTP1.1流复用-HT…

SpringBoot整合H2数据库并将其打包成jar包、转换成exe文件二(补充)

SpringBoot整合H2数据库并将其打包成jar包、转换成exe文件二&#xff08;补充&#xff09; 如果你想在cmd命令窗口内看到程序运行&#xff0c;即点开弹出运行窗口&#xff0c;关闭时exe自动关闭。 需要再launch4j上进行如下操作&#xff1a; 这样转换好的exe就可以有控制台了…

springboot + Vue前后端项目(第十六记)

项目实战第十六记 写在前面1 第一个bug1.1 完整的Role.vue 2 第二个bug2.1 修改路由router下面的index.js 总结写在最后 写在前面 发现bug&#xff0c;修复bug 1 第一个bug 分配菜单时未加入父id&#xff0c;导致分配菜单失效 <!-- :check-strictly"true" 默…

人工智能对零售业的影响

机器人、人工智能相关领域 news/events &#xff08;专栏目录&#xff09; 本文目录 一、人工智能如何改变零售格局二、利用人工智能实现购物体验自动化三、利用人工智能改善库存管理四、通过人工智能解决方案增强客户服务五、利用人工智能分析消费者行为六、利用 AI 打造个性化…

C++前期概念(重)

目录 命名空间 命名空间定义 1. 正常的命名空间定义 2. 命名空间可以嵌套 3.头文件中的合并 命名空间使用 命名空间的使用有三种方式&#xff1a; 1:加命名空间名称及作用域限定符&#xff08;::&#xff09; 2:用using将命名空间中某个成员引入 3:使用using namespa…

TCP协议报头详解

目录 前言 TCP特点 TCP报头 1.源端口和目的端口 2.序号 3.确认号 4.数据偏移 5.保留 6.控制位 ① 紧急URG&#xff08;URGent&#xff09; ② 确认ACK&#xff08;ACKnowledgment&#xff09; ③ 推送PSH&#xff08;PuSH&#xff09; ④复位RST&#xff08;ReSeT&…

【数据结构】初识集合深入剖析顺序表(Arraylist)

【数据结构】初识集合&深入剖析顺序表&#xff08;Arraylist&#xff09; 集合体系结构集合的遍历迭代器增强for遍历lambda表达式 List接口中的增删查改List的5种遍历ArrayList详解ArrayList的创建ArrayList的增删查改ArrayList的遍历ArrayList的底层原理 &#x1f680;所属…

UnityAPI学习之 播放游戏音频的类(AudioSource)

播放游戏音频的类&#xff08;AudioSource&#xff09; using System.Collections; using System.Collections.Generic; using UnityEngine;public class NO17AudioSource : MonoBehaviour {private AudioSource audioSource;//音频组件public AudioClip clip;//音频文件public…

预编译、函数变量提升

函数声明会覆盖变量的声明&#xff0c;也就是会提升到最前面。 形参传进来相当于变量声明&#xff0c;所以当有函数声明时&#xff0c;会被覆盖。

情绪管理:大我则定,小我则乱(王阳明)

学了很多知识&#xff0c;却还是感物易动&#xff1f;如何让心回归中正&#xff1f;王阳明一言以蔽之&#xff1a; —— 大我&#xff0c;大我则定&#xff0c;小我则乱 保持心静的方法&#xff1a;有大爱&#xff0c;为大局着想