您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 如何覆盖BaseHTTPRequestHandler log_message()方法以记录到文件而不是控制台(sys.stderr)?

5b51 2022/1/14 8:23:30 python 字数 2389 阅读 604 来源 www.jb51.cc/python

我正在使用BaseHTTPServer.HTTPServer创建Web服务 我想记录以下内容以记录到文件而不是控制台.但我还没有设法找到办法. 10.23.23.19 - - [29/Nov/2013 08:39:06] "GET / HTTP/1.1" 200 - 10.23.23.19 - - [29/Nov/2013 08:39:06] "POST / HTTP/1.1" 200 - 10.

概述

我想记录以下内容以记录到文件而不是控制台.但我还没有设法找到办法.

10.23.23.19 - - [29/Nov/2013 08:39:06] "GET / HTTP/1.1" 200 -
10.23.23.19 - - [29/Nov/2013 08:39:06] "POST / HTTP/1.1" 200 -
10.24.20.14 - - [29/Nov/2013 08:39:27] "POST / HTTP/1.1" 200 -
10.24.20.14 - - [29/Nov/2013 08:39:31] "POST / HTTP/1.1" 200 -

我的代码看起来像这样:

from BaseHTTPServer import HTTPServer
from pysimplesoap.server import SoapDispatcher,SOAPHandler
.
# The rest of the code
.
.
httpd = HTTPServer(("",8059),SOAPHandler)
    httpd.dispatcher = dispatcher
    httpd.serve_forever()

我正在使用Python 2.6

Log an arbitrary message.

This is used by all other logging functions. Override it if you have
specific logging wishes.

所以解决方案显然是单独留下.send_response()(显然你希望发送你的响应),并用一个适当的记录器(参见http://docs.python.org/2/library/logging.html)替换.log_message(),这是一种干净而灵活的方法.处理Python中的日志记录,或者如果您只想快速入侵文件系统文件.

总结

以上是编程之家为你收集整理的python – 如何覆盖BaseHTTPRequestHandler log_message()方法以记录到文件而不是控制台(sys.stderr)?全部内容,希望文章能够帮你解决python – 如何覆盖BaseHTTPRequestHandler log_message()方法以记录到文件而不是控制台(sys.stderr)?所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶