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

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

Dec 02, 2023 am 09:17 AM
php websocket リアルタイムのメッセージプッシュ

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 までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles