0

0

php连接websocket用fsockopen行吗_php连接websocketfsockopen法【步骤】

看不見的法師

看不見的法師

发布时间:2026-02-02 11:31:02

|

461人浏览过

|

来源于php中文网

原创

fsockopen 可连接 WebSocket 但需手动实现完整协议:先拼接含 Sec-WebSocket-Key 的 HTTP 握手请求并校验 Sec-WebSocket-Accept 响应,再按 RFC 6455 手动分帧(客户端消息必掩码)、处理跨包数据、超时重试等,否则易连而不用。

php连接websocket用fsockopen行吗_php连接websocketfsockopen法【步骤】

fsockopen 连 WebSocket 协议本身是可行的,但不能直接“连上就发消息”

WebSocket 是基于 HTTP 升级(Upgrade: websocket)的协议,fsockopen 只能建立原始 TCP 连接并发送/接收裸字节,它不解析 HTTP 头、不处理 WebSocket 帧格式(如掩码、opcode、长度编码)。所以你得自己拼接握手请求、校验响应头、再手动打包/解包数据帧——这不是“连接”,而是“从零实现客户端”。

  • 握手阶段必须发送正确的 Sec-WebSocket-Key,服务端会用它生成 Sec-WebSocket-Accept 响应,少一个 header 或 base64 错一位都会失败
  • 后续所有消息必须按 WebSocket 规范(RFC 6455)分帧:客户端发的消息必须带掩码(mask=1),服务端发的不能掩码;你漏掉 mask key 或没异或 payload,对方直接断连
  • fsockopen 没有超时重试、心跳保活、自动重连逻辑,出错后全靠你自己 fgets/fwrite + feof + fclose 手动兜底

实际项目中用 fsockopen 连 WebSocket 的典型错误现象

最常见的不是连不上,而是“连上了却收不到消息”或“发一条就断”。比如:

  • 握手返回 HTTP/1.1 101 Switching Protocols,但缺少 Sec-WebSocket-Accept 或值校验失败 → 连接被服务端静默关闭
  • 发消息时没设 mask 位(第 9 个 bit),或 mask key 四字节没参与 payload 异或 → 服务端按协议直接 close 连接,状态码常为 1002
  • 读取响应时只用 fgets($fp),但 WebSocket 数据帧可能跨 TCP 包到达,fgets 遇不到换行就阻塞或截断 → 后续帧解析全乱

fsockopen 更靠谱的替代方案

除非你在嵌入式环境或极度受限的 PHP 环境(连 ext-sockets 都没编译),否则别硬刚 fsockopen。推荐路径:

  • ext-sockets + 自己写帧逻辑:比 fsockopen 更底层可控,支持非阻塞、select 轮询,适合长连接管理
  • reactphp/socket + textalk/websocket:Composer 安装即用,自动处理握手、ping/pong、分帧、重连,$conn->send()$conn->on('message', ...) 就完事
  • 如果只是偶尔发指令(比如通知前端刷新),改用服务端 HTTP 接口 + 前端 WebSocket 主动轮询或监听事件,绕开 PHP 端维持 WebSocket 连接的复杂度

真要用 fsockopen,关键步骤不能跳

最小可运行握手示例的核心环节(省略错误处理):

秘塔AI搜索
秘塔AI搜索

秘塔AI搜索,没有广告,直达结果

下载

立即学习PHP免费学习笔记(深入)”;

$host = 'echo.websocket.org';
$port = 80;
$fp = fsockopen($host, $port, $errno, $errstr, 5);
if (!$fp) die("connect failed: $errstr ($errno)");

// 生成 Sec-WebSocket-Key(必须是 16 字节随机 base64)
$key = base64_encode(random_bytes(16));

// 发送握手请求
$request = "GET / HTTP/1.1\r\n";
$request .= "Host: $host\r\n";
$request .= "Upgrade: websocket\r\n";
$request .= "Connection: Upgrade\r\n";
$request .= "Sec-WebSocket-Key: $key\r\n";
$request .= "Sec-WebSocket-Version: 13\r\n\r\n";
fwrite($fp, $request);

// 读响应头(直到遇到空行)
$response = '';
while (!feof($fp) && ($line = fgets($fp)) !== false) {
    $response .= $line;
    if ($line === "\r\n") break;
}

// 校验 HTTP 状态和 Accept 头
if (strpos($response, "HTTP/1.1 101") === false) {
    die("handshake failed");
}
$accept = 'Sec-WebSocket-Accept: ' . base64_encode(
    sha1($key . '258EAFA5-E914-47DA-95CA-C5AB0DC85B11', true)
);
if (strpos($response, $accept) === false) {
    die("accept mismatch");
}

到这里才算“握手成功”。之后所有通信都要按 RFC 6455 手动构造帧——这才是真正容易翻车的地方,比如掩码 key 必须每次随机、payload 长度超过 125 要扩展 length 字段、控制帧(ping)必须原样 echo 回去……这些细节一旦出错,连接立刻中断,且很难定位。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.12.25

fclose函数的用法
fclose函数的用法

fclose是一个C语言和C++中的标准库函数,用于关闭一个已经打开的文件,是文件操作中非常重要的一个函数,用于将文件流与底层文件系统分离,释放相关的资源。更多关于fclose函数的相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

334

2023.11.30

fclose函数的用法
fclose函数的用法

fclose是一个C语言和C++中的标准库函数,用于关闭一个已经打开的文件,是文件操作中非常重要的一个函数,用于将文件流与底层文件系统分离,释放相关的资源。更多关于fclose函数的相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

334

2023.11.30

fgets在c语言中的用法
fgets在c语言中的用法

本专题整合了c语言中fgets用法介绍,阅读专题下面的文章了解更多详细内容。

16

2025.08.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1206

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

235

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2181

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.01.19

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

5

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号