搭建Twisted Reactor TCP 服务器与客户端(文末有福利)

来源:互联网 发布:爱喝啤酒软件 编辑:程序博客网 时间:2024/06/05 20:43
Twisted是用Python实现的基于事件驱动的网络引擎框架。
Twisted使用了更多的基于事件的方式。要写一个基本的服务器,你要实现事件处理 器,它处理诸如一个新的客户端连接、新的数据到达和客户端连接中断等情况。在Twisted中,你的事件处理器定义在一个protocol中;你也需要一 个factory,当一个新的连接到达时它能够构造这个protocol对象,但是如果你仅仅想创建一个自定义的Protocol类的实例的话,你可以使 用来自Twisted的factory,Factory类在模块twisted.internet.protocol中。当你写你的protocol时, 使用twisted.internet.protocol模块中的Protocol作为你的父类。当你得到一个连接时,事件处理器 connectionMade被调用;当你丢失了一个连接时,connectionLost被调用。从客户端接受数据使用处理器 dataReceived。但是你不能使用事件处理策略向客户端发送数据;要向客户端发送数据,你可以使用self.transport,它有一个 write方法。它也有一个client属性,其中包含了客户端的地址(主机名和端口)。

下面这个例子是一个Twisted版的服务器。 其中实例化了Factory并设置了它的protocol属性以便它知道使用哪个protocol与客户端通信(这就是所谓的你的自定义 protocol)。然后你使用factory开始监听指定的端口,factory通过实例化的protocol对象处理连接。监听使用reactor模 块中的listenTCP函数。最后,你通过调用reactor模块中的run函数来开始服务器。
服务器代码如下:
#!/usur/bin/env python#-*- coding:UTF-8 -*-import twistedfrom twisted.internet.protocol import Protocol,Factoryfrom twisted.internet import reactorfrom time import ctimePORT=21567class TSServProtocol (protocol.Protocol)    def connectionMade(self):        clnt=self.clnt=self.transport.getPeer().host        print '...connected from :',clnt    def dataReceived(self,data):        self.transport.write('[%s] %s'%(ctime(),data))factory=protocol.Factory()factory.protocol=TSServProtocalprint 'waiting for connection...'reactor.listenTCP(PORT,factory)reactor.run()
败笔:运行报错,百思不得解
File "E:/python/xiang mu/tsTservTW.py", line 11    class TSServProtocol (protocol.Protocol)                                  ^SyntaxError: invalid syntaxProcess finished with exit code 1
客户端代码:
#!/usur/bin/env python#-*- coding:UTF-8 -*-from twisted.internet.protocol import Protocolfrom twisted.internet import reactorHOST='localhost'PORT=21567class TSClntProtocol (protocol.Protocol)    def sendData(self):        data=raw_input('> ')        if data:            print '...sending %s...'%data            self.transport.write(data)        else:            self.transport.loseConnection()    def connectionMade(self):        self.sendData()    def dataReceived(self,data):        print data        self.sendData()class TSClntFactory(protocol.ClientFactory):    protocol=TSClntProtocol    clientConnectionLost=clientConnectionFailed= \        lambda self, connector, reason:reactor.stop()reactor.connectTCP(HOST,PORT,TSClntFactory())reactor.run()

样报有PROTOCOL模块的相关错误:求大神指闭嘴闭嘴惊恐教!!!!!!!!!!!!!!!!!!