加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 如何覆盖BaseHTTPRequestHandler log_message()方法以

发布时间:2020-12-16 23:44:52 所属栏目: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.2
我正在使用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.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

解决方法

如果您阅读BaseHTTPRequestHandler的文档或源代码,您会发现所有日志记录都通过BaseHTTPRequestHandler.log_message()进行,docstring明确指定:

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中的日志记录,或者如果您只想快速入侵文件系统文件.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读