zoukankan      html  css  js  c++  java
  • python编程(基于twisted的client编程)

    【 声明:版权全部,欢迎转载。请勿用于商业用途。 联系信箱:feixiaoxing @163.com】


        python的twisted比較有意思,既能够做server方面的编程,也能够做client方面的编程。关于这方面的编程。最简单的样例就是echo。


        client 代码例如以下,

    #!/usr/bin/python
    
    from twisted.internet.protocol import Protocol, ClientFactory
    from sys import stdout
    from twisted.internet import reactor
    
    class Echo(Protocol):
    	def dataReceived(self, data):
    		stdout.write(data)
     
    class EchoClientFactory(ClientFactory):
    	def startedConnecting(self, connector):
    		print 'Started to connect.'
       
    	def buildProtocol(self, addr):
    		print 'Connected.'
    		return Echo()
       
    	def clientConnectionLost(self, connector, reason):
    		print 'Lost connection. Reason:', reason
    	
    	def clientConnectionFailed(self, connector, reason):
    		print 'Connection failed. Reason:', reason
    
    if __name__ == '__main__':
    	reactor.connectTCP('localhost', 1234, EchoClientFactory())
    	reactor.run()

        server 代码例如以下,

    #!/usr/bin/python
    
    from twisted.internet import protocol, reactor, endpoints
    
    class Echo(protocol.Protocol):
        def dataReceived(self, data):
            self.transport.write(data)
    
    class EchoFactory(protocol.Factory):
        def buildProtocol(self, addr):
            return Echo()
    
    if __name__ == '__main__':
        endpoints.serverFromString(reactor, "tcp:1234").listen(EchoFactory())
        reactor.run()
    
    


  • 相关阅读:
    jUnit4初探(1)
    关于冒泡排序与选择排序
    我对直接插入排序的一点理解
    Java中的Scanner类
    String数组与字符串类
    Redis知识点详解
    MySQL操作命令详解
    java中常见面试题整理
    Redis的安装部署
    zookeeper的伪集群部署步骤
  • 原文地址:https://www.cnblogs.com/yutingliuyl/p/7137426.html
Copyright © 2011-2022 走看看