WebSocket est un protocole de communication full-duplex sur une seule connexion TCP. Le protocole de communication WebSocket a été désigné comme norme RFC 6455 par l'IETF en 2011 et a été complété par la RFC7936. L'API WebSocket a également été désignée comme standard par le W3C.
WebSocket facilite l'échange de données entre le client et le serveur, permettant au serveur de transmettre activement les données au client. Dans l'API WebSocket, le navigateur et le serveur n'ont besoin que d'effectuer une poignée de main, et une connexion persistante peut être créée directement entre les deux pour une transmission de données bidirectionnelle.
Moins de frais généraux de contrôle. Lorsque des données sont échangées entre le serveur et le client après la création d'une connexion, les en-têtes de paquets utilisés pour le contrôle du protocole sont relativement petits. Sans extensions, pour le contenu serveur à client, la taille de l'en-tête n'est que de 2 à 10 octets (liée à la longueur du paquet) ; pour le contenu client à serveur, des en-têtes supplémentaires doivent être ajoutés. Par rapport aux requêtes HTTP qui comportent à chaque fois des en-têtes complets, cette surcharge est considérablement réduite.
Des performances en temps réel plus fortes. Le protocole étant en duplex intégral, le serveur peut envoyer des données de manière proactive au client à tout moment. Comparé aux requêtes HTTP, qui doivent attendre que le client lance une requête avant que le serveur puisse répondre, le délai est nettement inférieur, même par rapport à des méthodes d'interrogation longues similaires telles que Comet, elles peuvent fournir des données plus de fois sur une courte période ; temps.
Restez connecté. Contrairement à HTTP, Websocket doit d'abord créer une connexion, ce qui en fait un protocole avec état, et certaines informations d'état peuvent être omises lors des communications ultérieures. Les requêtes HTTP peuvent devoir contenir des informations d'état (telles que l'authentification de l'identité, etc.) dans chaque requête.
Meilleur support binaire. Websocket définit des trames binaires, qui peuvent gérer le contenu binaire plus facilement que HTTP.
peut prendre en charge les extensions. Websocket définit des extensions et les utilisateurs peuvent étendre le protocole et implémenter certains sous-protocoles personnalisés. Par exemple, certains navigateurs prennent en charge la compression, etc.
Meilleur effet de compression. Par rapport à la compression HTTP, Websocket, avec la prise en charge des extensions appropriées, peut hériter du contexte du contenu précédent et améliorer considérablement le taux de compression lors de la transmission de données similaires.
WebSocket est un protocole indépendant créé sur TCP.
Websocket effectue une prise de contact via le code d'état 101 du protocole HTTP/1.1.
Afin de créer une connexion Websocket, une demande doit être effectuée via le navigateur, puis le serveur répond. Ce processus est souvent appelé « handshaking ».
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!