工程优化——WebSocket、WSS(WebSocket Secure)和SSE(Server-Sent Events)通信对比

发布于:2025-06-27 ⋅ 阅读:(17) ⋅ 点赞:(0)

WebSocket、WSS(WebSocket Secure)和SSE(Server-Sent Events)是三种常见的实时通信技术,它们的核心区别在于通信方向、协议实现、数据格式和适用场景。以下是分维度的详细解释,并附带Python示例和应用场景选择原则。


1. 核心区别

维度 WebSocket WSS(WebSocket Secure) SSE(Server-Sent Events)
通信方向 双向通信(客户端 ↔ 服务端) 双向通信(加密版) 单向通信(服务端 → 客户端)
协议 自定义协议(ws:// 或 wss://) 加密版(wss://) 基于HTTP协议(HTTP/1.1 长连接)
数据格式 支持文本和二进制数据 支持文本和二进制数据 仅支持纯文本(UTF-8)
连接方式 需升级HTTP连接(握手) 加密版(升级HTTP连接) 直接使用HTTP长连接
自动重连 需手动实现 需手动实现 浏览器自动重连
跨域支持 支持(需配置CORS) 支持(需配置CORS) 不能跨域(HTTP get请求)
适用场景 实时双向交互(如聊天、游戏) 高安全性场景(如金融交易) 单向数据推送(如新闻、日志更新)

2. 简单类比与例子

  • WebSocket:像一对情侣互相发消息,随时可以聊天、打游戏,实时性高。
    例子:在线多人游戏(玩家A打字,玩家B立刻看到)。
  • SSE:像老师在黑板上写新内容,学生只能被动接收,不能主动提问。
    例子:新闻网站实时更新头条新闻。
  • WSS:WebSocket的加密版,类似情侣在公共场合发消息时,用加密方式保护隐私。

3. Python实现示例

WebSocket(双向通信)
# 服务端(使用websockets库)
import asyncio
import websockets

async def echo(websocket, path):
    async for message in websocket:
        await websocket.send(f"服务端收到: {message}")

start_server = websockets.serve(echo, "localhost", 8765)

asyncio.get_event_loop().run_until_complete(start_server)
asyncio.get_event_loop().run_forever()
SSE(单向通信)
# 服务端(使用asyncio)
import asyncio
from http.server import BaseHTTPRequestHandler, HTTPServer

class SSEHandler(BaseHTTPRequestHandler):
    def do_GET(self):
        self.send_response(200)
        self.send_header('Content-Type', 'text/event-stream')
        self.send_header('Cache-Control', 'no-cache')
        self.end_headers()
        while True:
            asyncio.run(self.serve())

    async def serve(self):
        await asyncio.sleep(1)  # 模拟延迟
        self.wfile.write(b"新消息\n\n")
        self.wfile.flush()

def run_server():
    server = HTTPServer((host, port), SSEHandler)
    server.serve_forever()

if __name__ == "__main__":
    run_server()
WSS(加密WebSocket)
# 服务端(使用websockets + ssl)
import asyncio
import websockets
import ssl

async def wss_echo(websocket, path):
    async for message in websocket:
        await websocket.send(f"加密通道收到: {message}")

ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2)
ssl_context.load_cert_chain("server.crt", "server.key")

start_server = websockets.serve(wss_echo, "localhost", 8766, ssl=ssl_context)
asyncio.get_event_loop().run_until_complete(start_server)
asyncio.get_event_loop().run_forever()

4. 应用场景选择原则

场景 推荐技术 理由
实时双向交互(如聊天) WebSocket 支持双向通信,适合需要实时反馈的场景。
单向数据推送(如新闻) SSE 基于HTTP协议,实现简单,适合服务器主动推送文本数据。
高安全性需求(如金融) WSS 加密通信,防止数据被窃听。
跨域通信需求 WebSocket 通过配置CORS可跨域,而SSE因HTTP限制无法跨域。

5. 总结

  • WebSocket:适合需要双向实时通信的场景,功能强大但复杂度较高。
  • SSE:轻量级单向通信,适合简单推送场景,实现简单但不支持双向。
  • WSS:WebSocket的加密版本,适合对安全性要求高的场景。

网站公告

今日签到

点亮在社区的每一天
去签到