我试图使用axios向flask服务器进行POST请求:
var config = { headers: {
'Content-Type': 'application/json',
'Access-Control-Allow-Origin': '*'}
}
axios.post("http://127.0.0.1:5000/test",
{ label : "Test" , text : "Test"} , config
)
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
现在是 Flask 的部分
...
data = request.get_json(silent=True)
item = {'label': data.get('label'), 'text': data.get('text')}
print item
...
然而,最终会出现以下错误:
XMLHttpRequest无法加载http://127.0.0.1:5000/test。预检请求的响应未能通过访问控制检查:所请求的资源上没有'Access-Control-Allow-Origin'标头。因此,源'http://localhost:3000'无法访问。
为什么?我已经按建议设置了标头。
以下是解决方案:
from flask_cors import CORS, cross_origin
app = Flask(__name__)
cors = CORS(app, resources={r"/YOURAPP/*": {"origins": "*"}})