我目前正在使用 Python BaseHTTPServer
,我需要覆盖handle_timeout()
服务器的方法。
根据 Python 的文档(https://docs.python.org/2/library/basehttpserver.html),BaseHTTPServer是 TCPServer 的子类。TCPServer 实现了我想要覆盖的方法handle_timeout
(https://docs.python.org/2/library/socketserver.html#SocketServer.BaseServer.handle_timeout )。
我的代码目前看起来像这样:
class newServer(BaseHTTPServer.HTTPServer):
def handle_timeout(self):
print "Timeout!"
class RequestHandler(BaseHTTPServer.BaseHTTPRequestHandler):
def setup(self):
self.timeout=2
BaseHTTPServer.BaseHTTPRequestHandler.setup(self)
if __name__ == '__main__':
server=newServer
httpd = server((HOST_NAME, PORT_NUMBER), RequestHandler)
print time.asctime(), "Server Starts - %s:%s" % (HOST_NAME, PORT_NUMBER)
try:
httpd.serve_forever()
except KeyboardInterrupt:
pass
httpd.server_close()
print time.asctime(), "Server Stops - %s:%s" % (HOST_NAME, PORT_NUMBER)
超时本身有效,我从服务器收到以下消息:
Request timed out: timeout('timed out',)
问题是,这不是我想要打印的消息。对我的问题有帮助吗?