与SocketServer TCP客户端不一样的是,这个例子与之前的所有其他客户端看上去都不大一样。它是完全Twisted的。
例16.8 Twisted Reactor Timestamp TCP客户端(tsTclntTW.py)
用Twisted重写我们已经熟悉的时间戳TCP客户端。
1#!/usr/bin/env python |
逐行解释
1~6行
跟之前所有的客户端程序类似,这里还是导入Twisted的组件。
8~22行
与服务器一样,我们扩展Protocol,重写同样的函数connectionMade()和dataReceived()。这两个函数的用途也跟服务器一样。我们新加一个自己的函数sendData(),用于在需要发送数据时调用。
由于我们现在是客户端,所以我们要主动发起跟服务器的对话。一旦连接建立好之后,我们先发送一个消息,服务器回复这个消息,我们把收到的回复显示在屏幕上,然后再发送其他消息给服务器。
这个过程会一直循环,直到用户没有给任何输入时,连接结束。结束时,就不是调用transport对象的write()函数传数据给服务器了,而是调用loseConnection()函数来关闭套接字。这时,工厂的client ConnectionLost()函数会被调用,同时,reactor就被关闭,脚本的执行就结束了。由于某些原因,clientConnectionFailed()被调用时,reactor也会被关闭。
脚本的最后一部分是创建一个客户端工厂,连接到服务器,然后运行reactor。注意,我们在这里实例化了客户端工厂,而不是像在服务器里那样把它传到reactor中。这是因为,我们不是等待客户端连接的服务器,服务器在有连接时要为每个连接创建一个新的protocol对象。我们只是一个客户端,所以我们只要创建一个protocol对象,连接到服务器,服务器的工厂会创建一个protocol对象来与我们对话。