在Flask或WSGI中打印原始HTTP请求

时间:2014-08-23 22:26:12

标签: python flask wsgi

我正在调试我已构建的微控制器,它逐行写入原始HTTP请求。我正在使用Flask作为后端,我希望看到以这种格式显示的整个请求:

GET / HTTP/1.1
Content-length: 123
User-agent: blah
...

我知道Flask基于WSGI。反正有没有让它与Flask合作?

7 个答案:

答案 0 :(得分:35)

是的,Flask是一个WSGI应用程序,因此将您的应用程序包装在记录请求的额外层中是微不足道的:

import pprint

class LoggingMiddleware(object):
    def __init__(self, app):
        self._app = app

    def __call__(self, environ, resp):
        errorlog = environ['wsgi.errors']
        pprint.pprint(('REQUEST', environ), stream=errorlog)

        def log_response(status, headers, *args):
            pprint.pprint(('RESPONSE', status, headers), stream=errorlog)
            return resp(status, headers, *args)

        return self._app(environ, log_response)

这定义了一个用于包装Flask应用程序的中间件。优点是它完全独立于Flask运行,让您无需过滤即可了解进入的内容和出现的内容。

如何应用中间件取决于您使用的确切WSGI服务器;请参阅您的WSGI服务器文档。

使用内置服务器(app.run())运行Flask时,请执行以下操作:

if __name__ == '__main__':
    app.wsgi_app = LoggingMiddleware(app.wsgi_app)
    app.run()

app.wsgi_app包裹舞会将LoggingMiddleware放在Flask WSGI应用程序周围。

输出转到wsgi.error流;最终的结果取决于您的WSGI服务器; mod_wsgi将此信息放入您网站的Apache错误日志中,捆绑的Flask服务器将其打印到stderr

答案 1 :(得分:25)

使用flask,您可以访问包含所有HTTP详细信息的请求对象:

from flask import request

@app.route('/')
def index():
    print request.headers

答案 2 :(得分:14)

假设您需要完整的详细信息,

还有另一种方式

@app.route('/')
def index():
    print request.__dict__
    #this prints all variables in `dict` format including `headers`

答案 3 :(得分:5)

这不会使用烧瓶,但设置socket echo server非常简单。

import socket

host = ''
port = 8888
backlog = 5
size = 1024
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind((host,port))
s.listen(backlog)
while 1:
    client, address = s.accept()
    data = client.recv(size)
    if data:
        client.send(data)
    client.close()

答案 4 :(得分:5)

为什么不呢?

from flask import Flask, request

app = Flask(__name__)

@app.before_request
def log_request():
    app.logger.debug("Request Headers %s", request.headers)
    return None

# The remaining application code.

我已经使用了标题,但您可以使用相同的方法打印任何请求属性。文档在这里:http://flask.pocoo.org/docs/0.12/api/#flask.Request

此外,您需要将FLASK_DEBUG = 1设置为Flask.logger.debug才能正常工作,因为您可以在生产中禁用它。

此致

答案 5 :(得分:0)

如果您使用的是记录器,我会发现这很有用

https://docs.python.org/3/library/pprint.html#pprint.pformat

from pprint import pformat
import requests
log.debug(pformat(request.headers))

答案 6 :(得分:0)

您可能想要类似的东西

print(request.headers)
print(request.data)
print(request.args)
print(request.form)
print(request.endpoint)
print(request.method)
print(request.remote_addr)