ホームページ >バックエンド開発 >PHPチュートリアル >PHP を使用して Websocket を開発し、リアルタイム メッセージ プッシュ システムを作成する

PHP を使用して Websocket を開発し、リアルタイム メッセージ プッシュ システムを作成する

PHPz
PHPzオリジナル
2023-12-02 09:17:30719ブラウズ

PHP を使用して Websocket を開発し、リアルタイム メッセージ プッシュ システムを作成する

PHP を使用して WebSocket を開発し、リアルタイム メッセージ プッシュ システムを作成する


  1. はじめに
  2. リアルタイム通信のニーズの増加に伴い、 WebSocket に基づくリアルタイム メッセージ プッシュ システム Web 開発での人気が高まっています。この記事では、PHP を使用して、リアルタイム メッセージ プッシュ機能を実装する簡単な WebSocket アプリケーションを開発する方法を紹介します。

  3. WebSocket とは何ですか?
  4. WebSocket は、単一の TCP 接続を介した全二重双方向通信のためのプロトコルです。従来の HTTP プロトコルと比較して、WebSocket はより高速なリアルタイム データ送信を実現でき、リアルタイムのメッセージ プッシュが必要なシナリオに適しています。

  5. 開発環境の準備
  6. 始める前に、次のツールと環境を準備する必要があります:
  7. PHP 7.0: この記事ではサーバー側言語として PHP を使用しており、PHP の言語を使用する必要があります。 WebSocket 拡張機能。
  8. Apache または Nginx: Web サーバーとして、クライアントとサーバー間の WebSocket 接続を確立するために使用されます。
  9. WebSocket クライアント: WebSocket をサポートする任意のブラウザまたはデバッグ ツールを使用できます。

  10. サーバー側のコード例
  11. まず、サーバー側で WebSocket サーバー インスタンスを作成し、指定されたポートをリッスンする必要があります。

// 创建WebSocket服务器实例,监听指定端口
$server = new SwooleWebSocketServer('0.0.0.0', 9501);

// 监听WebSocket连接打开事件
$server->on('open', function (SwooleWebSocketServer $server, SwooleHttpRequest $request) {
    echo "WebSocket连接打开
";
});

// 监听WebSocket消息事件
$server->on('message', function (SwooleWebSocketServer $server, SwooleWebSocketFrame $frame) {
    echo "收到消息:{$frame->data}
";
    // 推送消息给所有连接的客户端
    $server->push($frame->fd, "服务器收到消息:{$frame->data}");
});

// 监听WebSocket连接关闭事件
$server->on('close', function (SwooleWebSocketServer $server, int $fd) {
    echo "WebSocket连接关闭
";
});

// 启动WebSocket服务器
$server->start();

上記のコードは、Swoole 拡張機能を使用して WebSocket サーバー インスタンスを作成し、ポート 9501 をリッスンします。クライアントが接続するか、メッセージを送信するか、接続を閉じるたびに、対応するイベント ハンドラーがトリガーされます。

  1. クライアント コードの例
  2. 次に、サーバーとのリアルタイム通信を実現するために、クライアント側で WebSocket 接続を確立する必要があります。

<!DOCTYPE html>
<html>
<head>
    <title>WebSocket示例</title>
</head>
<body>
    <script type="text/javascript">
        // 创建WebSocket对象,与服务器建立连接
        var ws = new WebSocket('ws://localhost:9501');

        // 监听WebSocket连接打开事件
        ws.onopen = function () {
            console.log('WebSocket连接已打开');
        };

        // 监听WebSocket消息事件
        ws.onmessage = function (event) {
            console.log('收到消息:' + event.data);
        };

        // 监听WebSocket连接关闭事件
        ws.onclose = function () {
            console.log('WebSocket连接已关闭');
        };

        // 发送消息
        function sendMessage() {
            var message = document.getElementById('message').value;
            ws.send(message);
        }
    </script>

    <input type="text" id="message" placeholder="输入消息" />
    <button onclick="sendMessage()">发送消息</button>
</body>
</html>

上記のコードは、ブラウザ側で JavaScript を使用して WebSocket オブジェクトを作成し、サーバーとの接続を確立します。 WebSocket イベントをリッスンすることで、メッセージの受信、送信、接続クロージャのキャプチャなどの機能を実装できます。

  1. 実行とテスト
  2. コマンド ライン ウィンドウでサーバー側のコードを実行して、WebSocket サーバーを起動します。次に、ブラウザでクライアント ページを開き、WebSocket 接続を確立します。

これで、クライアント ページにメッセージを入力して送信できるようになります。サーバーは対応するメッセージを受信して​​応答します。同時に、受信したメッセージがクライアントページに表示されます。

  1. 概要
  2. この記事の導入部分を通じて、PHP を使用して簡単な WebSocket アプリケーションを開発し、リアルタイム メッセージ プッシュ機能を実装する方法を学習できます。もちろん、上記のコードは単なる基本的な例であり、実際のニーズに応じて拡張および最適化できます。

WebSocket のリアルタイム通信機能は、Web 開発の可能性をさらに広げ、特にチャット アプリケーション、リアルタイムの監視、通知などのシナリオに適しています。この記事は、WebSocket 開発を開始し、より多くの創造性とアイデアを刺激するのに役立つと信じています。 ###

以上がPHP を使用して Websocket を開発し、リアルタイム メッセージ プッシュ システムを作成するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。