我的应用程序将使用以下简单的线程文件服务器:

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,但这些方法不变。

07-28 07:53