我的应用程序将使用以下简单的线程文件服务器:
class FileServer(Thread):
"""Simple file server exposing the current directory for the thumbnail
creator
"""
def __init__(self, port):
Thread.__init__(self)
self.port = port
Handler = SimpleHTTPServer.SimpleHTTPRequestHandler
self.httpd = SocketServer.TCPServer(("", port), Handler)
def run(self):
self.httpd.serve_forever()
def stop(self):
self.httpd.shutdown()
如何防止simplehttpserver在每次请求时输出“get”http://bla bla bla?谢谢
最佳答案
您可以子类化SimpleHTTPServer.SimpleHTTPRequestHandler
并重写log_message
方法。下面是您要覆盖的方法,sans-docstring:
def log_message(self, format, *args):
sys.stderr.write("%s - - [%s] %s\n" %
(self.address_string(),
self.log_date_time_string(),
format%args))
因此,为了简单地忽略所有消息,将函数体替换为
pass
。对于更细粒度的控制(即,如果仍然希望打印错误消息),您可以重写log_request
和/或log_error
方法。原始方法如下:def log_request(self, code='-', size='-'):
self.log_message('"%s" %s %s',
self.requestline, str(code), str(size))
def log_error(self, format, *args):
self.log_message(format, *args)
模块名称从2.7更改为3.1,但这些方法不变。