Maison > développement back-end > Tutoriel Python > Introduction à la programmation côté serveur WebSocket dans Tornado de Python

Introduction à la programmation côté serveur WebSocket dans Tornado de Python

不言
Libérer: 2018-10-20 15:37:02
avant
3007 Les gens l'ont consulté
Cet article vous présente une introduction à la programmation du serveur WebSocket dans Python's Tornado. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il vous sera utile.

Tornado définit la classe tornado.websocket.WebSocketHandler pour gérer les demandes de liens WebSocket. Les développeurs d'applications doivent hériter de cette classe et implémenter ses fonctions open(), on_message() et on_close().

  • Fonction WebSocketHandler.open() : Le framework Tornado appellera cette fonction lorsqu'une nouvelle connexion WebSocket est établie. Dans cette fonction, les développeurs peuvent utiliser la fonction get_argument() pour obtenir les paramètres soumis par le client comme dans get(), post() et d'autres fonctions, et utiliser get_secure_cookie/set_secure_cookir pour faire fonctionner les cookies, etc.

  • Fonction WebSocketHandler.on_message(message) : Après avoir établi le lien WebSocket, le framework Tornado appellera cette fonction lorsqu'un message du client est reçu. Il s'agit généralement de la fonction principale de la programmation WebSocket côté serveur, qui traite le message reçu en conséquence. Fonction

  • WebSocketHandler.on_close() : Lorsque le lien WebSocket est fermé, le framework Tornado appellera cette fonction. Dans cette fonction, vous pouvez interroger la raison de la fermeture en accédant à self.close_code et self.close_reason.

En plus de ces trois fonctions d'entrée automatiquement appelées par le framework Tornado, WebSocketHandler propose également deux développeurs pour exploiter activement les fonctions WebSocket.

  • Fonction WebSocketHandler.write_message(message,binary=False) : utilisée pour écrire des messages au client relatifs à ce lien. Fonction

  • WebSocketHandler.close(code=None,reason=None) : ferme activement le lien WebSocket. Le code et le motif sont utilisés pour indiquer au client pourquoi le lien est fermé. Le code du paramètre doit être une valeur numérique et le motif est une chaîne.

Ce qui suit est le programme Tornado WebSocket qui envoie continuellement des messages horaires au client :

import tornado.ioloop
import tornado.web
import tornado.websocket
from tornado import gen
from tornado.options import define,options,parse_command_line
import asyncio

clients=dict()#客户端Session字典

class IndexHandler(tornado.web.RequestHandler):
    @tornado.web.asynchronous
    @gen.coroutine
    def get(self):
        print("123")
        self.render("index.html")

class MyWebSocketHandler(tornado.websocket.WebSocketHandler):
    def open(self, *args, **kwargs): #有新链接时被调用
        self.id=self.get_argument("Id")
        self.stream.set_nodelay(True)
        clients[self.id]={"id":self.id,"object":self}#保存Session到clients字典中

    def on_message(self, message):#收到消息时被调用
        print("Client %s received a message:%s"%(self.id,message))

    def on_close(self): #关闭链接时被调用
        if self.id in clients:
            del clients[self.id]
            print("Client %s is closed"%(self.id))

    def check_origin(self, origin):
        return True
app=tornado.web.Application([
    (r'/',IndexHandler),
    (r'/websocket',MyWebSocketHandler),
])


import threading
import time
class SendThread(threading.Thread):
    # 启动单独的线程运行此函数,每隔1秒向所有的客户端推送当前时间
    def run(self):
        # tornado 5 中引入asyncio.set_event_loop,不然会报错
        asyncio.set_event_loop(asyncio.new_event_loop())
        import datetime
        while True:
            for key in clients.keys():
                msg = str(datetime.datetime.now())
                clients[key]["object"].write_message(msg)
                print("write to client %s:%s" % (key, msg))
            time.sleep(1)





if __name__ == '__main__':
    #启动推送时间线程
    SendThread().start()
    parse_command_line()
    app.listen(8888)
    #挂起运行
    tornado.ioloop.IOLoop.instance().start()
Copier après la connexion

Le code ci-dessus est analysé comme suit :

  • Le dictionnaire de variables globales clients est défini pour enregistrer toutes les informations client qui établissent des liens WebSocket avec le serveur. La clé du dictionnaire est l'identifiant du client, et la valeur est un tuple composé de l'identifiant et de l'instance WebSocketHandler correspondante

  • IndexHandler est un processeur de page ordinaire utilisé pour signaler aux clients Rendre le page d'accueil index.html côté client. Cette page contient le programme client WebSocket.

  • MyWebSocketHandler est le processeur principal de cet exemple, hérité de tornado.web.WebSocketHandler. La fonction open() enregistre toutes les connexions client au dictionnaire des clients ; on_message() est utilisé pour afficher les messages du client ; on_close() est utilisé pour supprimer les liens WebSocket fermés du dictionnaire des clients.

  • La fonction sendTime() s'exécute dans un thread séparé, interroge tous les clients dans les clients toutes les secondes et envoie des messages horaires au client via la fonction MyWebSocketHandler.write_message().

  • Dans cet exemple, seules deux routes sont configurées dans l'instance tornado.web.Application, pointant respectivement vers IndexHandler et MyWebSocketHandler, qui sont toujours démarrées et exécutées par Tornado IOLoop.

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!

Étiquettes associées:
source:segmentfault.com
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal