Flask Web接口跨域
环境
Python3.7.0
macOS High Sierra 10.13.6
Flask1.0.2
跨域文件上传的时候,浏览器会自动发起一个 OPTIONS 方法到服务器,现在后台解决前端跨域解决前端跨域请求的问题
客户端发起的这个 OPTIONS 可以说是一个“预请求”,用于探测后续真正需要发起的跨域 POST 请求对于服务器来说是否是安全可接受的,因为跨域提交数据对于服务器来说可能存在很大的安全问题
请求头 Access-Control-Request-Method 用于提醒服务器在接下来的请求中将会使用什么样的方法来发起请求
Access-Control-Allow-Method 和 Access-Control-Allow-Origin 分别告知客户端,服务器允许客户端用于跨域的方法和域名
下载flask_cors
sudo pip3 install flask_cors
flask_cors==3.0.6
flask_cors使用
from flask import Flask
from flask_cors import CORS
app=Flask(__name__)
CORS(app,resources=r'/*')
示例1
from flask import Flask,jsonify
app=Flask(__name__)
test={
'name':'aaa',
'age':'18'
}
@app.route('/',methods=['GET'])
def Test():
return jsonify(test)
def main():
app.run()
if __name__ == '__main__':
main()
Headers:
Content-Length →26
Content-Type →application/json
Date →Mon, 27 Aug 2018 10:57:20 GMT
Server →Werkzeug/0.14.1 Python/3.7.0
示例2
from flask import Flask,jsonify
from flask_cors import CORS
app=Flask(__name__)
CORS(app,resources=r'/*')
test={
'name':'aaa',
'age':'18'
}
@app.route('/',methods=['GET'])
def Test():
return jsonify(test)
def main():
app.run()
if __name__ == '__main__':
main()
Headers:
Access-Control-Allow-Origin →*
Content-Length →26
Content-Type →application/json
Date →Mon, 27 Aug 2018 11:02:52 GMT
Server →Werkzeug/0.14.1 Python/3.7.0
很容易发现两个headers多了个Access-Control-Allow-Origin字段
Access-Control-Allow-Origin:
Specifies a URI that may access the resource. For requests without credentials, the server may specify '*' as a wildcard, thereby allowing any origin to access the resource.