HTML5 - WebSockets

WebSockets est une technologie de communication bidirectionnelle de nouvelle génération pour les applications Web qui fonctionne sur un seul socket et est exposée via une interface JavaScript dans les navigateurs compatibles HTML 5.

Une fois que vous avez établi une connexion Web Socket avec le serveur Web, vous pouvez envoyer des données du navigateur au serveur en appelant un send() méthode, et recevez des données du serveur au navigateur par un onmessage gestionnaire d'événements.

Voici l'API qui crée un nouvel objet WebSocket.

var Socket = new WebSocket(url, [protocal] );

Ici, le premier argument, url, spécifie l'URL à laquelle se connecter. Le deuxième attribut, protocole, est facultatif et, s'il est présent, spécifie un sous-protocole que le serveur doit prendre en charge pour que la connexion réussisse.

Attributs WebSocket

Voici l'attribut de l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

N ° Sr. Attribut et description
1

Socket.readyState

L'attribut readonly readyState représente l'état de la connexion. Il peut avoir les valeurs suivantes -

  • Une valeur de 0 indique que la connexion n'a pas encore été établie.

  • Une valeur de 1 indique que la connexion est établie et que la communication est possible.

  • Une valeur de 2 indique que la connexion est en cours de négociation de clôture.

  • Une valeur de 3 indique que la connexion a été fermée ou n'a pas pu être ouverte.

2

Socket.bufferedAmount

L'attribut en lecture seule bufferedAmount représente le nombre d'octets de texte UTF-8 qui ont été mis en file d'attente à l'aide de la méthode send ().

Événements WebSocket

Voici les événements associés à l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

un événement Gestionnaire d'événements La description
ouvert Socket.onopen Cet événement se produit lorsque la connexion socket est établie.
message Socket.onmessage Cet événement se produit lorsque le client reçoit des données du serveur.
Erreur Socket.onerror Cet événement se produit en cas d'erreur de communication.
Fermer Socket.onclose Cet événement se produit lorsque la connexion est fermée.

Méthodes WebSocket

Voici les méthodes associées à l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

N ° Sr. Méthode et description
1

Socket.send()

La méthode d'envoi (données) transmet les données à l'aide de la connexion.

2

Socket.close()

La méthode close () serait utilisée pour mettre fin à toute connexion existante.

Exemple WebSocket

Un WebSocket est une socket TCP bidirectionnelle standard entre le client et le serveur. Le socket démarre comme une connexion HTTP, puis "Mises à niveau" vers un socket TCP après une prise de contact HTTP. Après la poignée de main, chaque côté peut envoyer des données.

Code HTML et JavaScript côté client

Au moment de la rédaction de ce didacticiel, seuls quelques navigateurs Web prennent en charge l'interface WebSocket (). Vous pouvez essayer l'exemple suivant avec la dernière version de Chrome, Mozilla, Opera et Safari.

<!DOCTYPE HTML>

<html>
   <head>
      
      <script type = "text/javascript">
         function WebSocketTest() {
            
            if ("WebSocket" in window) {
               alert("WebSocket is supported by your Browser!");
               
               // Let us open a web socket
               var ws = new WebSocket("ws://localhost:9998/echo");
				
               ws.onopen = function() {
                  
                  // Web Socket is connected, send data using send()
                  ws.send("Message to send");
                  alert("Message is sent...");
               };
				
               ws.onmessage = function (evt) { 
                  var received_msg = evt.data;
                  alert("Message is received...");
               };
				
               ws.onclose = function() { 
                  
                  // websocket is closed.
                  alert("Connection is closed..."); 
               };
            } else {
              
               // The browser doesn't support WebSocket
               alert("WebSocket NOT supported by your Browser!");
            }
         }
      </script>
		
   </head>
   
   <body>
      <div id = "sse">
         <a href = "javascript:WebSocketTest()">Run WebSocket</a>
      </div>
      
   </body>
</html>

Installez pywebsocket

Avant de tester le programme client ci-dessus, vous avez besoin d'un serveur prenant en charge WebSocket. Téléchargez mod_pywebsocket-xxxtar.gz depuis pywebsocket qui vise à fournir une extension Web Socket pour Apache HTTP Server et installez-le en suivant ces étapes.

  • Décompressez et décompressez le fichier téléchargé.

  • Aller à l'intérieur pywebsocket-x.x.x/src/ annuaire.

  • Construction de $ python setup.py

  • installation de $ sudo python setup.py

  • Ensuite, lisez le document par -

    • $ pydoc mod_pywebsocket

Cela l'installera dans votre environnement python.

Démarrez le serveur

Aller au pywebsocket-x.x.x/src/mod_pywebsocket dossier et exécutez la commande suivante -

$sudo python standalone.py -p 9998 -w ../example/

Cela lancera l'écoute du serveur sur le port 9998 et utilisera le handlers répertoire spécifié par l'option -w où réside notre echo_wsh.py.

Maintenant, en utilisant le navigateur Chrome, ouvrez le fichier html que vous avez créé au début. Si votre navigateur prend en charge WebSocket (), alors vous obtiendrez une alerte indiquant que votre navigateur prend en charge WebSocket et enfin lorsque vous cliquez sur "Exécuter WebSocket", vous obtiendrez un message d'au revoir envoyé par le script du serveur.