我想将我的所有http标头响应设置为以下内容:
response.headers["X-Frame-Options"] = "SAMEORIGIN"
我检查了this question,但它只更改了一个特定控制器的标头。我想在“before_request”函数中更改所有标题,类似于以下逻辑。我怎么能这样做?
@app.before_request
def before_request():
# response.headers["X-Frame-Options"] = "SAMEORIGIN"
答案 0 :(得分:41)
在@app.after_request()
hook中设置标题,此时您有一个响应对象来设置标题:
@app.after_request
def apply_caching(response):
response.headers["X-Frame-Options"] = "SAMEORIGIN"
return response
此挂钩运行时flask.request
context仍然可用,因此您仍可以根据请求更改响应。
答案 1 :(得分:0)
@app.after_request() hook
不足以满足我的用例。
我的用例如下:我有一个谷歌云函数,我想为所有响应设置CORS标头。可能会有多个响应,因为我必须验证输入并在出现问题时返回,我必须处理数据并可能在出现故障时提早返回等。因此,我创建了如下帮助函数:
# Helper function to return a response with status code and CORS headers
def prepare_response(res_object, status_code):
response = flask.jsonify(res_object)
response.headers.set('Access-Control-Allow-Origin', '*')
response.headers.set('Access-Control-Allow-Methods', 'GET, POST')
return response, status_code
因此,当我想返回响应(总是带有CORS标头)时,我现在可以调用此函数,并且我不会重复启用CORS所需的response.headers设置。
答案 2 :(得分:0)
我们可以使用WSGI中间件为Python Flask应用程序中的所有响应设置响应标头
使用中间件在Flask应用程序上下文中设置响应标头的这种方式是线程安全的,可用于设置自定义和动态属性,读取请求标头,如果我们要从任何帮助程序类设置自定义/动态响应标头,则这特别有用
文件:middleware.py
import flask
from flask import request, g
class SimpleMiddleWare(object):
"""
Simple WSGI middleware
"""
def __init__(self, app):
self.app = app
self._header_name = "any_request_header"
def __call__(self, environ, start_response):
"""
middleware to capture request header from incoming http request
"""
request_id_header = environ.get(self._header_name) # reading all request headers
environ[self._header_name] = request_id_header
def new_start_response(status, response_headers, exc_info=None):
"""
set custom response headers
"""
# set the above captured request header as response header
response_headers.append((self._header_name, request_id_header))
# example to access flask.g values set in any class thats part of the Flask app & then set that as response header
values = g.get(my_response_header, {})
if values.get('x-custom-header'):
response_headers.append(('x-custom-header', values.get('x-custom-header')))
return start_response(status, response_headers, exc_info)
return self.app(environ, new_start_response)
从主类中调用中间件
文件:main.py
from flask import Flask
import asyncio
from gevent.pywsgi import WSGIServer
from middleware import SimpleMiddleWare
app = Flask(__name__)
app.wsgi_app = SimpleMiddleWare(app.wsgi_app)