


PHP et WebSocket : bonnes pratiques pour le transfert de données en temps réel
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 :
- Version PHP >= 7.0 ;
- Outil Composer.
Les étapes d'installation sont les suivantes :
- Créez un nouveau répertoire de projet et entrez le répertoire dans la ligne de commande.
-
Utilisez Composer pour installer la bibliothèque Ratchet. Entrez la commande suivante sur la ligne de commande :
composer require cboden/ratchet
Copier après la connexionCela téléchargera et installera automatiquement la bibliothèque Ratchet et ses dépendances.
- 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. onOpen
、onMessage
、onClose
和onError
,用于处理客户端连接、收到消息、关闭连接和处理错误。
在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
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 :
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.
- 4. Exécutez et testez
- 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.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total
