正在尝试将CORS添加到我的flask应用程序中,该应用程序正在使用flask-restx创建的API。希望这里有人能发现我做错了什么。
在运行flask的控制台中,我没有得到任何相关日志,网站上说Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://127.0.0.1/api/v1/test. (Reason: CORS request did not succeed). Status code: (null).
这是我的用户案例的复制,它给了我同样的错误,并模仿了我的设置方式。
from flask import Flask
from flask_cors import CORS
from flask_restx import Namespace, Resource, Api
from flask import jsonify, make_response
from flask import Blueprint, render_template_string
import logging
logging.basicConfig()
LOGGER = logging.getLogger("reprod-case")
LOGGER.setLevel(logging.DEBUG)
LOGGER.info("Created LOGGER")
logging.getLogger('flask_cors').level = logging.DEBUG
# Create the restx namespace with a specified path
ns = Namespace(name='api_v1', path="/api/v1")
@ns.route('/test')
class Deck(Resource):
def get(self):
print("get")
return make_response(jsonify({"message": "You did a Get!"}), 200)
def put(self):
print("Put")
return None, 201
html_page = """
<html lang="en">
<body>
<button type="submit" name="myButton" value="Value">Click Me</button>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script>
$(document).ready(function() {
$('button').on('click',function(e){
const vote_value = e.currentTarget.attributes.value.value;
console.log()
$.ajax({
type: 'GET',
crossDomain: true,
withCredentials: true,
url: 'http://127.0.0.1/api/v1/test',
contentType: 'application/json'
})
});
});
</script>
</body>
</html>
"""
# Blueprint for the webpage and add a route
bp = Blueprint("/", __name__)
@bp.route('/')
def home_route():
return render_template_string(html_page)
# Setup the app, Cors, add the namespace and blueprint
def create_app():
app = Flask(__name__)
# CORS(app, resources={r"/api/*": {"origins": "*"}},
CORS(app,
resources={r"/api/*": {"origins": ['http://192.168.50.16:5000', 'http://localhost:5000']}},
supports_credentials=True
)
api = Api(doc="/api/", title="Endpoints")
api.add_namespace(ns, path="/api/v1")
app.register_blueprint(bp)
api.init_app(app)
return app
if __name__ == "__main__":
app_ = create_app()
app_.run(debug=True)
我还尝试通过设置after_request
来启用cors
@app.after_request
def enable_cors(response):
response.headers.add("Access-Control-Allow-Headers", "authorization,content-type")
response.headers.add("Access-Control-Allow-Methods", "DELETE, GET, HEAD, OPTIONS, PATCH, POST, PUT")
response.headers.add("Access-Control-Allow-Origin", "*")
return response
请参阅RapidAPI的这篇博客文章https://rapidapi.com/guides/handle-cors-flask