python – 如何覆盖BaseHTTPRequestHandler log_message()方法以记录到文件而不是
发布时间:2020-09-16 06:48:16 所属栏目: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.
我正在使用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明确指定:
所以解决方案显然是单独留下.send_response()(显然你希望发送你的响应),并用一个适当的记录器(参见http://docs.python.org/2/library/logging.html)替换.log_message(),这是一种干净而灵活的方法.处理Python中的日志记录,或者如果您只想快速入侵文件系统文件. (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- 我可以执行ipython脚本吗?
- python-2.7 – Sphinx的LaTeX错误:找不到文件`t
- python – 有人可以解释为什么这会修复我的递归错
- python – 停止使用apt-get安装已安装的依赖项
- 当我运行python manage.py syncdb时,Django避免在
- python – 如何使用扭曲的raw_input?
- python – 什么是django.utils.functional .__ p
- 如何从python源代码中删除注释和doc字符串?
- python – 用py2exe创建的可执行文件不能在windo
- python:re.sub的replace函数不接受额外的参数 –
热点阅读