我正在调试我已构建的微控制器,它逐行写入原始HTTP请求。我正在使用Flask作为后端,我希望看到以这种格式显示的整个请求:
GET / HTTP/1.1
Content-length: 123
User-agent: blah
...
我知道Flask基于WSGI。反正有没有让它与Flask合作?
答案 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)