Flask サーバーへの CORS リクエストを許可するのに問題があります。クライアントは axios を使用した React です。クライアントのエラーは次のとおりです。
Access to XMLHttpRequest at <url> has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
ブラウザーで (いずれかの PC で) URL に直接移動すると、問題なく読み込まれます。しかし、axiosを使用すると壊れます。
私は次の戦略を試しました:
1) ヘッダーを直接追加:
from wsgiref.simple_server import make_server
import falcon
import transform
import json
import engine
index = transform.reindex()
app = falcon.API()
class Search:
def on_get(self, request, response):
query = request.params['searchText']
result = engine.search(query, index)
response.append_header('access-control-allow-origin', '*')
response.status = falcon.HTTP_200
response.body = json.dumps(result)
search = Search()
app.add_route('/search', search)
if __name__ == '__main__':
with make_server('', 8003, app) as httpd:
print('Serving on port 8003...')
httpd.serve_forever()
2) ミドルウェアを介してグローバルに falcon_cors を使用する:
from wsgiref.simple_server import make_server
import falcon
from falcon_cors import CORS
from flask import jsonify
import transform
import json
import engine
cors = CORS(allow_origins_list=[
'<client ip>'
])
index = transform.reindex()
app = falcon.API(middleware=[cors.middleware])
class Search:
def on_get(self, request, response):
query = request.params['searchText']
result = engine.search(query, index)
response.status = falcon.HTTP_200
response.body = json.dumps(result)
search = Search()
app.add_route('/search', search)
if __name__ == '__main__':
with make_server('', 8003, app) as httpd:
print('Serving on port 8003...')
httpd.serve_forever()
1) falcon-cors をローカルで使用する:
from wsgiref.simple_server import make_server
import falcon
from falcon_cors import CORS
from flask import jsonify
import transform
import json
import engine
cors = CORS(allow_origins_list=['*'])
index = transform.reindex()
app = falcon.API(middleware=[cors.middleware])
public_cors = CORS(allow_all_origins=True)
class Search:
cors = public_cors
def on_get(self, request, response):
query = request.params['searchText']
response.status = falcon.HTTP_200
response.body = json.dumps(result)
search = Search()
app.add_route('/search', search)
if __name__ == '__main__':
with make_server('', 8003, app) as httpd:
print('Serving on port 8003...')
httpd.serve_forever()
何も機能していません。ブラウザーで応答を調べると、'access-control-allow-origin': '*' が表示されます。axios が常にすべてのヘッダーを表示できるとは限らないことをどこかで読みました。誰もこれに遭遇したことがありますか?ありがとうございました。