怎样用PHP实现websocket?实时通信服务搭建指南

爱谁谁
发布: 2025-07-10 17:14:02
原创
444人浏览过

用 php 实现 websocket 需要借助 cli 模式和 sockets 扩展或框架如 ratchet;1. 安装 php cli 并启用 sockets 扩展;2. 使用 socket_create 等函数实现原生 websocket 服务,完成握手和数据帧解析;3. 推荐使用 ratchet 框架简化开发,通过 composer 安装并创建监听类和启动脚本;4. 注意避免在 apache/fpm 下运行,确保端口开放并设计心跳机制;5. 生产环境可结合 workermanswoole 提升性能。

怎样用PHP实现websocket?实时通信服务搭建指南

用 PHP 实现 WebSocket 其实并不复杂,但也不是像写个 HTML 页面那样直接。因为 PHP 本身是面向 HTTP 请求的脚本语言,而 WebSocket 是一种长连接、双向通信的协议,需要额外借助一些工具或扩展来实现。

怎样用PHP实现websocket?实时通信服务搭建指南

不过只要掌握了基本原理和流程,你就能在自己的项目中搭建起一个简单的实时通信服务了。下面我们就一步步来看怎么做。


准备工作:了解基础和环境要求

WebSocket 是基于 TCP 的协议,客户端和服务端建立连接后,可以互相发送消息。PHP 要实现 WebSocket 服务端,不能依赖传统的 Apache + mod_php 模式,而是需要用 CLI(命令行)方式运行一个常驻进程。

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

怎样用PHP实现websocket?实时通信服务搭建指南

你需要:

  • 安装 PHP CLI 环境
  • 推荐使用 Sockets 扩展(默认一般都启用)
  • 可选:安装 Ratchet 这类框架简化开发

如果你是在本地测试,XAMPP 或 WAMP 都支持 CLI;如果是服务器环境,确保可以通过命令行执行 PHP 脚本。

怎样用PHP实现websocket?实时通信服务搭建指南

原生 PHP 实现 WebSocket 的核心步骤

如果你不想引入额外框架,可以直接使用 socket_create 和相关函数来实现一个最简版的 WebSocket 服务。以下是主要流程:

  1. 创建 socket 并绑定地址和端口
  2. 监听连接请求
  3. 接受客户端连接并处理握手
  4. 解析和响应 WebSocket 数据帧
  5. 循环读取和发送消息

握手部分要特别注意,客户端发起 WebSocket 请求时会带 Sec-WebSocket-Key 头,服务端需要计算对应的响应值,否则连接会被拒绝。

示例代码片段如下:

$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
socket_bind($socket, '0.0.0.0', 8080);
socket_listen($socket);

$client = socket_accept($socket);
$request = socket_read($client, 2048);

// 解析 Sec-WebSocket-Key
preg_match("/Sec-WebSocket-Key: (.*)\r\n/", $request, $matches);
$key = base64_encode(pack('H*', sha1($matches[1] . '258EAFA5-E914-47DA-95CA-C5AB6DC6DEAD')));

$headers = "HTTP/1.1 101 Switching Protocols\r\n";
$headers .= "Upgrade: websocket\r\n";
$headers .= "Connection: Upgrade\r\n";
$headers .= "Sec-WebSocket-Accept: $key\r\n\r\n";
socket_write($client, $headers, strlen($headers));

// 开始收发数据
while (true) {
    $data = socket_read($client, 1024);
    // 解析数据帧...
}
登录后复制

这只是一个简化版本,实际使用中还要处理断开连接、多客户端管理等问题。


使用 Ratchet 框架更省事

如果你想更快上手,推荐使用 Ratchet,这是一个专为 PHP 设计的 WebSocket 框架,封装好了握手、消息解析等底层逻辑。

安装方式很简单,用 Composer 即可:

composer require cboden/ratchet
登录后复制

然后创建一个监听类,比如 Chat.php:

use Ratchet\MessageComponentInterface;
use Ratchet\ConnectionInterface;

class Chat implements MessageComponentInterface {
    public function onOpen(ConnectionInterface $conn) {
        echo "New connection!\n";
    }

    public function onMessage(ConnectionInterface $from, $msg) {
        $from->send("You said: $msg");
    }

    public function onClose(ConnectionInterface $conn) {
        echo "Connection closed\n";
    }

    public function onError(ConnectionInterface $conn, \Exception $e) {
        echo "Error: {$e->getMessage()}\n";
    }
}
登录后复制

再写一个启动脚本 server.php:

use Ratchet\Server\IoServer;
use Ratchet\Http\HttpServer;
use Ratchet\WebSocket\WsServer;

require dirname(__DIR__).'/vendor/autoload.php';

$server = IoServer::factory(
    new HttpServer(new WsServer(new Chat())),
    8080
);

$server->run();
登录后复制

然后运行:

php server.php
登录后复制

这样就起了一个完整的 WebSocket 服务,支持多个客户端连接和消息转发。


注意事项和常见问题

  • 不要在 Apache/FPM 下运行 WebSocket:这些环境不适合长连接,只能用 CLI 方式启动。
  • 防火墙和端口开放:确保服务器的对应端口(如 8080)对客户端开放。
  • 心跳机制:长时间不通讯可能被中间设备断开,建议定期发送 ping/pong 消息保持连接。
  • 生产环境部署:Ratchet 适合小规模使用,如果并发量大,建议结合 Workerman、Swoole 等高性能方案。

基本上就这些。虽然 PHP 不是天生适合做 WebSocket 的语言,但通过合适的工具和结构设计,还是能很好地完成实时通信的任务。

以上就是怎样用PHP实现websocket?实时通信服务搭建指南的详细内容,更多请关注php中文网其它相关文章!

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

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

下载
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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