科技与狠活 發表於 2026-5-3 17:22:14

PHP调用Workerman5.0实现一对一聊天

<div id="navCategory"><h5 class="catalogue">目录</h5><ul class="first_class_ul"><li><a href="#_label0">1. 安装 Workerman</a></li><li><a href="#_label1">2. 后端代码</a></li><li><a href="#_label2">3. 前端代码</a></li><li><a href="#_label3">4. 运行服务器</a></li><li><a href="#_label4">5. 测试</a></li><li><a href="#_label5">总结</a></li></ul></div><p>要实现一对一聊天功能,使用 Workerman 5.0 作为后端,前端可以使用 WebSocket 进行通信。以下是实现步骤和代码示例。</p>
<p class="maodian"><a name="_label0"></a></p><h2>1. 安装 Workerman</h2>
<p>首先,确保你已经安装了 Workerman。可以通过 Composer 安装:</p>
<div class="jb51code"><pre class="brush:bash;">composer require workerman/workerman
</pre></div>
<p class="maodian"><a name="_label1"></a></p><h2>2. 后端代码</h2>
<p>创建一个 PHP 文件(例如 chat_server.php),用于处理 WebSocket 连接和消息传递。</p>
<div class="jb51code"><pre class="brush:php;">&lt;?php
require_once __DIR__ . '/vendor/autoload.php';

use Workerman\Worker;
use Workerman\Connection\TcpConnection;

// 创建一个 WebSocket 服务器
$ws_worker = new Worker("websocket://0.0.0.0:2346");

// 保存用户连接的数组
$users = [];

// 当有客户端连接时
$ws_worker-&gt;onConnect = function(TcpConnection $connection) use (&amp;$users) {
    echo "New connection\n";
};

// 当有客户端发送消息时
$ws_worker-&gt;onMessage = function(TcpConnection $connection, $data) use (&amp;$users) {
    $message = json_decode($data, true);

    if (isset($message['type'])) {
      switch ($message['type']) {
            case 'login':
                // 用户登录,保存连接
                $users[$message['user_id']] = $connection;
                $connection-&gt;user_id = $message['user_id'];
                echo "User {$message['user_id']} logged in\n";
                break;

            case 'chat':
                // 一对一聊天
                if (isset($users[$message['to_user_id']])) {
                  $users[$message['to_user_id']]-&gt;send(json_encode([
                        'type' =&gt; 'chat',
                        'from_user_id' =&gt; $connection-&gt;user_id,
                        'message' =&gt; $message['message']
                  ));
                }
                break;
      }
    }
};

// 当客户端断开连接时
$ws_worker-&gt;onClose = function(TcpConnection $connection) use (&amp;$users) {
    if (isset($connection-&gt;user_id)) {
      unset($users[$connection-&gt;user_id]);
      echo "User {$connection-&gt;user_id} disconnected\n";
    }
};

// 运行 worker
Worker::runAll();
</pre></div>
<p class="maodian"><a name="_label2"></a></p><h2>3. 前端代码</h2>
<p>在前端,使用 WebSocket 连接到服务器,并实现登录和发送消息的功能。</p>
<div class="jb51code"><pre class="brush:xhtml;">&lt;!DOCTYPE html&gt;
&lt;html lang="en"&gt;
&lt;head&gt;
    &lt;meta charset="UTF-8"&gt;
    &lt;title&gt;WebSocket Chat&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;div&gt;
      &lt;input type="text" id="user_id" placeholder="Your User ID"&gt;
      &lt;button onclick="login()"&gt;Login&lt;/button&gt;
    &lt;/div&gt;
    &lt;div&gt;
      &lt;input type="text" id="to_user_id" placeholder="To User ID"&gt;
      &lt;input type="text" id="message" placeholder="Message"&gt;
      &lt;button onclick="sendMessage()"&gt;Send&lt;/button&gt;
    &lt;/div&gt;
    &lt;div id="chat"&gt;&lt;/div&gt;

    &lt;script&gt;
      let ws;
      let user_id;

      function login() {
            user_id = document.getElementById('user_id').value;
            ws = new WebSocket('ws://127.0.0.1:2346');

            ws.onopen = function() {
                ws.send(JSON.stringify({
                  type: 'login',
                  user_id: user_id
                }));
            };

            ws.onmessage = function(event) {
                const message = JSON.parse(event.data);
                if (message.type === 'chat') {
                  document.getElementById('chat').innerHTML += `&lt;p&gt;From ${message.from_user_id}: ${message.message}&lt;/p&gt;`;
                }
            };
      }

      function sendMessage() {
            const to_user_id = document.getElementById('to_user_id').value;
            const message = document.getElementById('message').value;
            ws.send(JSON.stringify({
                type: 'chat',
                to_user_id: to_user_id,
                message: message
            }));
      }
    &lt;/script&gt;
&lt;/body&gt;
&lt;/html&gt;
</pre></div>
<p class="maodian"><a name="_label3"></a></p><h2>4. 运行服务器</h2>
<p>在终端中运行 PHP 文件启动 WebSocket 服务器:</p>
<div class="jb51code"><pre class="brush:bash;">php chat_server.php start
</pre></div>
<p class="maodian"><a name="_label4"></a></p><h2>5. 测试</h2>
<p>打开两个浏览器窗口,分别输入不同的用户 ID 并登录。</p>
<p>在一个窗口中输入目标用户 ID 和消息,点击发送。</p>
<p>另一个窗口应该会收到消息并显示在页面上。</p>
<p class="maodian"><a name="_label5"></a></p><h2>总结</h2>
<p>通过以上步骤,你可以实现一个简单的一对一聊天系统。Workerman 作为后端处理 WebSocket 连接和消息传递,前端通过 WebSocket 与服务器通信,实现实时聊天功能。</p>
頁: [1]
查看完整版本: PHP调用Workerman5.0实现一对一聊天