带CORS的烧瓶服务静态文件夹

时间:2020-01-23 17:40:06

标签: python flask cors static-files

在我的前端应用程序中,我试图访问我在静态文件夹中提供的文件,但是CORS出现问题。我看到的问题是

Access to XMLHttpRequest at 'http://127.0.0.1:5000/static_folder/apple.xml' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

我的后端Flask应用具有以下设置

app = Flask(__name__, static_url_path='/static_folder', static_folder="static_folder")

似乎我需要在返回文件时在响应中添加“ Access-Control-Allow-Origin”标头。 Flask是否具有全局设置方式?

我尝试使用flask_cors,但操作失败

from flask_cors import CORS, cross_origin
app = Flask(__name__, static_url_path='/static_folder', static_folder="static_folder")
CORS(app)

通过将CORS标头设置为

,我可以使用SimpleHTTPRequestHandler得到类似的结果
def end_headers (self):
        self.send_header('Access-Control-Allow-Origin', '*')
        SimpleHTTPRequestHandler.end_headers(self)

但是我想使用flask完成此任务,而不是启动简单的http服务器。

2 个答案:

答案 0 :(得分:1)

在cors(app)之后添加以下行:

@app.after_request
def after_request(response):
    response.headers.add('Access-Control-Allow-Headers', 'Content-Type, Authorization')
    response.headers.add('Access-Control-Allow-Methods', 'GET, POST, PATCH, DELETE, OPTIONS')
    return response

答案 1 :(得分:0)

此外,如果使用flask-cors包,您应该可以覆盖您的静态请求:

from flask import Flask
from flask_cors import CORS

# Initialize
app = Flask(__name__)
cors = CORS(app, resources={r"/static/*": {"origins": "*"}})

祝你好运!