什么是 webSocket?攻击面、安全风险与测试要点

用burp测试web应用的时候,proxy除了http/https 还有websockets。

websockets用来干啥的,安全风险何在,如何测试。试着说一下。。。。


1 细数 Websocket and HTTP

协议层面:HTTP vs WebSocket

  • HTTP
    • 基于请求-响应模型,客户端必须主动发起请求,服务器才能返回数据。
    • 每次请求独立,通常是短连接(HTTP/1.1 支持 Keep-Alive,但仍是请求驱动)。
  • WebSocket
    • 在单个 TCP 连接上实现双向通信,握手完成后,客户端和服务器可互相主动发送消息,无需重复握手。
    • 有状态协议,连接保持打开,支持实时交互。

连接方式

  • HTTP
    • 每次请求都需完整 HTTP 报文头,开销大。
  • WebSocket
    • 握手阶段通过 HTTP 协议升级(Upgrade: websocket),之后切换到 WebSocket 协议。
    • 通信时仅需轻量级帧结构,开销小。

典型使用场景

  • HTTP:网页加载、API 调用、文件传输。
  • WebSocket :实时性要求高的应用,如:
    • 聊天系统
    • 在线游戏
    • 股票行情推送
    • 协作编辑

如何加固第一步+s

  • HTTP
    • 可使用 HTTPS 加密,成熟度高,安全工具支持广泛。
  • WebSocket
    • 可使用 WSS(WebSocket Secure),但安全测试工具支持较弱,渗透测试难度更高。

2 WebSocket 与 HTTP 的关系

  • 相同点
    • 都基于 TCP,都是应用层协议。
  • 不同点
    • WebSocket 支持双向通信,HTTP 单向。
    • WebSocket 需握手建立连接。
  • 联系
    • 握手阶段通过 HTTP,之后独立于 HTTP。

3 攻击面分析

根据 Black Hills Information SecurityWeb Security Academy 的研究,WebSocket 的攻击面包括:

  1. 协议降级攻击
    • 将 WebSocket 降级为 HTTP,利用客户端库漏洞(如 socket.io)。
  2. 握手中断
    • 在 HTTP Upgrade 阶段进行拦截或篡改,导致连接失败或劫持。
  3. 消息篡改与注入
    • 利用缺乏严格验证的消息格式,进行 XSS、命令注入。
  4. 认证与授权缺陷
    • 长连接状态下,令牌过期处理不当,导致会话劫持。
  5. DoS 攻击
    • 利用持续连接消耗服务器资源。

安全测试要点


总结

WebSocket 提供了高效的实时通信能力,但也带来了新的安全挑战。相比传统 HTTP,WebSocket 的攻击面更广,测试难度更高。安全团队应重点关注握手过程、消息验证、会话管理,并结合专业工具进行渗透测试。

相关推荐
枷锁—sha25 分钟前
【SRC】越权漏洞检测
运维·服务器·网络·安全·网络安全·系统安全
188号安全攻城狮1 小时前
【PWN】HappyNewYearCTF_8_ret2csu
linux·汇编·安全·网络安全·系统安全
啥都想学点2 小时前
kali 基础介绍(Command and Control、Exfiltration)
安全·网络安全
B2_Proxy2 小时前
IP 来源合规性,正在成为全球业务的隐性门槛
网络·爬虫·网络协议·安全
浩浩测试一下3 小时前
WAF绕过之编码绕过特性篇
计算机网络·web安全·网络安全·网络攻击模型·安全威胁分析·安全架构
Acrelhuang4 小时前
工商业用电成本高?安科瑞液冷储能一体机一站式解供能难题-安科瑞黄安南
大数据·开发语言·人工智能·物联网·安全
darkb1rd6 小时前
二、PHP 5.4-7.4版本演进与安全改进
安全·php·webshell
珠海西格6 小时前
远动通信装置为何是电网安全运行的“神经中枢”?
大数据·服务器·网络·数据库·分布式·安全·区块链
格林威7 小时前
Baumer相机铸件气孔与缩松识别:提升铸造良品率的 6 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·算法·安全·计算机视觉·堡盟相机·baumer相机
K·Herbert8 小时前
OpenClaw 私人电脑部署风险
人工智能·安全·编辑器