Maison >développement back-end >tutoriel php >PHP et WebSocket : bonnes pratiques pour le transfert de données en temps réel

PHP et WebSocket : bonnes pratiques pour le transfert de données en temps réel

WBOY
WBOYoriginal
2023-12-18 14:10:221358parcourir

PHP和WebSocket: 实现实时数据传输的最佳实践方法

PHP et WebSocket : meilleures méthodes pour réaliser une transmission de données en temps réel

Introduction :
Dans le développement d'applications Web, la transmission de données en temps réel est une exigence technique très importante. Le protocole HTTP traditionnel est un protocole de modèle requête-réponse et ne peut pas assurer efficacement la transmission de données en temps réel. Afin de répondre aux besoins de transmission de données en temps réel, le protocole WebSocket a vu le jour.

WebSocket est un protocole de communication full-duplex qui permet de communiquer en full-duplex via une seule connexion TCP. Par rapport au protocole HTTP, WebSocket peut permettre une transmission de données plus rapide et une transmission de données en temps réel. En raison de ses excellentes performances et de sa large prise en charge, WebSocket est largement utilisé dans les applications en temps réel.

Pour implémenter la communication WebSocket en PHP, nous pouvons utiliser certaines bibliothèques matures pour simplifier le processus de développement. Cet article présentera comment utiliser la bibliothèque Ratchet pour implémenter l'intégration de PHP et WebSocket, et fournira quelques bonnes pratiques afin que vous puissiez facilement créer des applications pour la transmission de données en temps réel.

1. Configurer l'environnement et installer les dépendances
Pour utiliser la bibliothèque Ratchet, vous devez remplir les conditions d'environnement et de dépendances suivantes :

  1. Version PHP >= 7.0 ;
  2. Outil Composer.

Les étapes d'installation sont les suivantes :

  1. Créez un nouveau répertoire de projet et entrez le répertoire dans la ligne de commande.
  2. Utilisez Composer pour installer la bibliothèque Ratchet. Entrez la commande suivante sur la ligne de commande :

    composer require cboden/ratchet

    Cela téléchargera et installera automatiquement la bibliothèque Ratchet et ses dépendances.

  3. Une fois l'installation terminée, vous pouvez commencer à utiliser Ratchet dans votre projet.

2. Créer un serveur WebSocket
En utilisant la bibliothèque Ratchet, vous pouvez facilement créer un serveur WebSocket. Voici un exemple de code simple :

use RatchetMessageComponentInterface;
use RatchetConnectionInterface;

require 'vendor/autoload.php';

class MyWebSocketServer implements MessageComponentInterface {
    protected $clients;

    public function __construct() {
        $this->clients = new SplObjectStorage;
    }

    public function onOpen(ConnectionInterface $conn) {
        $this->clients->attach($conn);
        echo "[New connection] - Connection ID: {$conn->resourceId}
";
    }

    public function onMessage(ConnectionInterface $from, $msg) {
        // 处理收到的消息
        foreach ($this->clients as $client) {
          if ($from !== $client) {
              $client->send($msg);
          }
        }
    }

    public function onClose(ConnectionInterface $conn) {
        $this->clients->detach($conn);
        echo "[Connection closed] - Connection ID: {$conn->resourceId}
";
    }

    public function onError(ConnectionInterface $conn, Exception $e) {
        echo "[Error] - Connection ID: {$conn->resourceId} - {$e->getMessage()}
";
        $conn->close();
    }
}

$server = new RatchetWebSocketWsServer(new MyWebSocketServer());
$server->disableVersion(0);
$server->loop->addPeriodicTimer(60, function() {
    // 定时任务
});

$socket = new ReactSocketServer('0.0.0.0:8080', $server->loop);
$server = new ReactHttpServer($socket, $server->loop);
$server->on('request', function ($request, $response) use (&$socket) {
    $response->end('Hello, World!');
});

echo "WebSocket server is running...
";

$server->run();

Dans cet exemple, nous créons d'abord une classe appelée "MyWebSocketServer" et implémentons l'interface MessageComponentInterface de Ratchet. Cette interface contient quatre méthodes : onOpen, onMessage, onClose et onError, qui sont utilisées pour gérer les connexions clients, recevoir des messages, fermer les connexions et gérer les erreurs. onOpenonMessageonCloseonError,用于处理客户端连接、收到消息、关闭连接和处理错误。

onOpen方法中,我们更新了服务器中的客户端列表,并打印出新连接的ID。

onMessage方法中,我们遍历了客户端列表,并将收到的消息发送给所有的客户端,除了消息来源的客户端。

onClose方法中,我们删除了客户端列表中的关闭连接,并打印出连接的ID。

onError方法中,我们处理了连接发生错误的情况,并关闭连接。

接下来,我们创建了一个WebSocket服务器的实例,并将MyWebSocketServer作为参数传递给了WsServer。然后,创建一个React HTTP服务器的实例。最后,我们通过run方法启动了WebSocket服务器。

三、前端客户端页面
为了测试WebSocket服务器,我们需要创建一个简单的前端页面,用于模拟WebSocket客户端。以下是一个示例页面:

<!DOCTYPE html>
<html>
<head>
    <title>WebSocket Client</title>
    <script>
        var socket = new WebSocket("ws://localhost:8080");

        socket.onmessage = function(event) {
            var message = event.data;
            // 处理收到的消息
            console.log(message);
        };

        // 发送消息
        function sendMessage() {
            var message = document.getElementById('message').value;
            socket.send(message);
        }
    </script>
</head>
<body>
    <input type="text" id="message" placeholder="Type a message...">
    <button onclick="sendMessage()">Send</button>
</body>
</html>

在这个示例中,我们首先创建了一个WebSocket对象并指定了服务器的地址和端口。然后,我们注册了onmessage

Dans la méthode onOpen, nous mettons à jour la liste des clients sur le serveur et imprimons l'ID de la nouvelle connexion.

Dans la méthode onMessage, nous parcourons la liste des clients et envoyons le message reçu à tous les clients sauf le client d'où provient le message.


Dans la méthode onClose, nous supprimons la connexion fermée dans la liste des clients et imprimons l'ID de connexion.

Dans la méthode onError, nous gérons la situation où une erreur se produit dans la connexion et fermons la connexion.

Ensuite, nous avons créé une instance du serveur WebSocket et passé MyWebSocketServer comme paramètre à WsServer. Ensuite, créez une instance du serveur HTTP React. Enfin, nous avons démarré le serveur WebSocket via la méthode run.

3. Page client front-end
Afin de tester le serveur WebSocket, nous devons créer une simple page front-end pour simuler le client WebSocket. Voici un exemple de page :

rrreee

Dans cet exemple, nous créons d'abord un objet WebSocket et spécifions l'adresse et le port du serveur. Ensuite, nous avons enregistré le gestionnaire d'événements onmessage pour gérer le message reçu. Dans cet exemple, nous imprimons simplement le message sur la console.

    De plus, nous avons ajouté une zone de saisie de texte et un bouton d'envoi pour permettre aux utilisateurs de saisir et d'envoyer des messages.
  1. 4. Exécutez et testez
  2. Après avoir exécuté le script du serveur WebSocket sur votre serveur, ouvrez le navigateur et visitez la page du client frontal. Vous verrez une zone de saisie de texte et un bouton d'envoi.
Entrez le message que vous souhaitez envoyer dans la zone de saisie de texte et cliquez sur le bouton Envoyer. Vous verrez le message reçu sur la console.

Avec des exemples de serveur WebSocket et de page client front-end, nous montrons comment utiliser la bibliothèque Ratchet et le code PHP et JavaScript associé. Grâce à cette approche, vous pouvez facilement créer des applications Web dotées de capacités de transfert de données en temps réel. 🎜🎜Conclusion : 🎜En utilisant le protocole WebSocket, nous pouvons réaliser une transmission de données en temps réel et fournir un moyen de communication plus rapide et plus efficace. PHP est un langage de programmation côté serveur populaire et WebSocket peut être facilement intégré aux applications PHP à l'aide de la bibliothèque Ratchet. L'exemple de code et les bonnes pratiques présentés dans cet article peuvent vous aider à commencer à créer des applications dotées de fonctionnalités de transfert de données en temps réel. 🎜🎜Références : 🎜🎜🎜Documentation officielle de Ratchet : http://socketo.me/docs/🎜🎜Documentation officielle de ReactPHP : https://reactphp.org/🎜🎜🎜Remarque : l'exemple de code dans cet article est à des fins de démonstration uniquement, ne couvre pas tous les détails et la gestion des exceptions. Dans le développement réel, veuillez apporter les améliorations et améliorations appropriées en fonction des besoins spécifiques. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn