Python - BaseHTTPServer - 覆盖“handle_timeout”方法

时间:2016-08-25 18:29:41

标签: python timeout basehttpserver

我目前正在使用Python的BaseHTTPServer,我需要覆盖服务器的handle_timeout()方法。

根据Python的文档(https://docs.python.org/2/library/basehttpserver.html),BaseHTTPServer是TCPServer的子类。 TCPServer实现了我想要覆盖的方法handle_timeouthttps://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',)

问题是,这不是我要打印的信息。 对我的问题有任何帮助吗?

1 个答案:

答案 0 :(得分:0)

对于任何有兴趣的人,在尝试了一些事情后,我终于得出结论:

根据此文件(https://svn.python.org/projects/python/trunk/Lib/BaseHTTPServer.py),我直接从BaseHTTPRequestHandler' handle_one_request - 方法复制了代码,并覆盖了最后几行以最终生成我的代码工作

我的所有其他尝试(在服务器类中覆盖它,在请求处理程序或main - 方法中捕获异常)似乎都不起作用。

希望这有时会帮助某人。