我目前正在使用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',)
问题是,这不是我要打印的信息。 对我的问题有任何帮助吗?
答案 0 :(得分:0)
对于任何有兴趣的人,在尝试了一些事情后,我终于得出结论:
根据此文件(https://svn.python.org/projects/python/trunk/Lib/BaseHTTPServer.py),我直接从BaseHTTPRequestHandler
' handle_one_request
- 方法复制了代码,并覆盖了最后几行以最终生成我的代码工作
我的所有其他尝试(在服务器类中覆盖它,在请求处理程序或main
- 方法中捕获异常)似乎都不起作用。
希望这有时会帮助某人。