导读:本期聚焦于小伙伴创作的《如何用Python实现实时WebSocket通信?FastAPI与客户端协同方案详解》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何用Python实现实时WebSocket通信?FastAPI与客户端协同方案详解》有用,将其分享出去将是对创作者最好的鼓励。

WebSocket是一种基于TCP的全双工通信协议,允许客户端和服务端建立持久连接后双向实时传输数据,避免了HTTP协议下频繁建立连接的开销,非常适合即时聊天、实时数据推送、在线协作等场景。Python的FastAPI框架内置了对WebSocket的良好支持,无需额外依赖复杂的第三方库就能快速搭建服务。

如何用Python实现实时WebSocket通信?FastAPI与客户端协同方案详解

WebSocket核心工作原理

WebSocket连接建立需要经过一次HTTP握手过程,客户端发送包含Upgrade: websocket头的请求,服务端验证通过后返回101状态码,之后连接就升级为WebSocket协议,双方可以随时向对方发送数据帧。整个通信过程中连接保持打开状态,直到任意一方主动关闭连接。

使用FastAPI搭建WebSocket服务端

首先确保已经安装了FastAPI和uvicorn,若未安装可以通过pip安装:

pip install fastapi uvicorn

下面是完整的FastAPI WebSocket服务端代码,实现接收客户端消息并回传的功能:

from fastapi import FastAPI, WebSocket
from fastapi.responses import HTMLResponse

app = FastAPI()

# 存储所有活跃的WebSocket连接
active_connections = []

@app.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket):
    # 接受客户端的WebSocket连接请求
    await websocket.accept()
    active_connections.append(websocket)
    try:
        while True:
            # 接收客户端发送的消息
            data = await websocket.receive_text()
            # 向当前客户端回传接收到的消息
            await websocket.send_text(f"服务端收到消息: {data}")
            # 可选:向所有活跃连接广播消息
            for connection in active_connections:
                if connection != websocket:
                    await connection.send_text(f"其他客户端发送了消息: {data}")
    except Exception as e:
        print(f"连接异常关闭: {e}")
    finally:
        # 连接关闭后从活跃列表中移除
        if websocket in active_connections:
            active_connections.remove(websocket)

# 提供一个简单的测试页面
@app.get("/")
async def get():
    html_content = """
    <html>
        <head>
            <title>WebSocket测试</title>
        </head>
        <body>
            <h1>WebSocket实时通信测试</h1>
            <input type="text" id="messageInput" placeholder="输入要发送的消息">
            <button onclick="sendMessage()">发送消息</button>
            <div id="messageArea"></div>
            <script>
                const ws = new WebSocket("ws://localhost:8000/ws");
                ws.onopen = function() {
                    console.log("WebSocket连接已建立");
                };
                ws.onmessage = function(event) {
                    const messageArea = document.getElementById("messageArea");
                    messageArea.innerHTML += "<p>" + event.data + "</p>";
                };
                ws.onclose = function() {
                    console.log("WebSocket连接已关闭");
                };
                function sendMessage() {
                    const input = document.getElementById("messageInput");
                    const message = input.value;
                    if (message) {
                        ws.send(message);
                        input.value = "";
                    }
                }
            </script>
        </body>
    </html>
    """
    return HTMLResponse(content=html_content)

运行服务端代码的命令如下:

uvicorn main:app --reload

启动后访问http://127.0.0.1:8000就能打开测试页面,输入消息点击发送即可看到服务端的回传。

编写Python客户端协同通信

除了前端客户端,也可以编写Python客户端与FastAPI服务端进行通信,下面是Python客户端的实现代码:

import asyncio
import websockets

async def websocket_client():
    # 连接到FastAPI的WebSocket服务
    async with websockets.connect("ws://127.0.0.1:8000/ws") as websocket:
        # 发送消息到服务端
        await websocket.send("这是Python客户端发送的消息")
        # 接收服务端的回传消息
        response = await websocket.recv()
        print(f"收到服务端响应: {response}")
        # 保持连接,持续接收消息
        while True:
            try:
                msg = await websocket.recv()
                print(f"收到新消息: {msg}")
            except Exception as e:
                print(f"连接关闭: {e}")
                break

if __name__ == "__main__":
    asyncio.run(websocket_client())

运行Python客户端前需要先安装websockets库:

pip install websockets

开发注意事项与优化建议

  • 连接管理:实际生产环境中需要对连接做更完善的异常处理,比如网络波动导致的连接断开自动重连机制。
  • 消息格式:建议使用JSON格式传输结构化数据,而不是直接传输纯文本,方便扩展消息类型。
  • 并发控制:FastAPI的WebSocket处理是异步的,高并发场景下需要注意资源占用,避免单个连接阻塞整个服务。
  • 鉴权处理:可以在WebSocket握手阶段添加鉴权逻辑,验证客户端的身份令牌,避免未授权连接接入。

常见问题解答

WebSocket连接握手失败怎么办

首先检查服务端路由是否正确,客户端连接的地址是否和服务端定义的WebSocket路由一致,其次确认服务端已经正常启动,端口没有被其他程序占用。

如何向指定客户端发送消息

可以在客户端连接时给每个连接绑定唯一标识,比如用户ID,发送消息时根据标识找到对应的连接对象再发送数据即可。

FastAPI的WebSocket支持二进制数据传输吗

支持,除了receive_textsend_text方法,还有receive_bytessend_bytes方法可以处理二进制数据,适合传输图片、文件等内容。

PythonWebSocketFastAPI实时通信修改时间:2026-06-23 02:33:34

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。