ホームページ >バックエンド開発 >Python チュートリアル >Flask アプリケーションの CORS 問題を解決する方法: なぜ「Access-Control-Allow-Origin」ヘッダーが必要なのでしょうか?
Flask アプリケーションで CORS の問題を解決する方法
クロスオリジン (CORS) リクエストを行う場合、欠落によるエラーが発生するのが一般的です。 「Access-Control-Allow-Origin」ヘッダー。この場合、サーバーがクライアントのオリジンからのリクエストを明示的に許可していないため、リクエストは拒否されています。
この問題を解決するには、「flask-cors」パッケージを使用して Flask アプリケーションで CORS を有効にします。方法は次のとおりです:
flask-cors をインストールします
<code class="bash">pip install -U flask-cors</code>
Flask をインポートします- CORS モジュール
<code class="python">from flask_cors import CORS, cross_origin</code>
CORS の構成
<code class="python">app = Flask(__name__) cors = CORS(app) app.config['CORS_HEADERS'] = 'Content-Type'</code>
CORS 有効ルートの装飾
<code class="python">@app.route("/") @cross_origin() def helloWorld(): return "Hello, cross-origin-world!"</code>
特定のケースでは、次のようにコードを変更できます:
クライアント コード:
<code class="javascript">// Only change the crossDomain option to false $.ajax({ type: 'POST', url: 'http://...', data: "name=3&email=3&phone=3&description=3", crossDomain: false, success: function(msg) { alert(msg); } });</code>
サーバー コード:
<code class="python">from flask import Flask, request from flask.ext.mandrill import Mandrill from flask_cors import CORS app = Flask(__name__) cors = CORS(app)</code>
注: クロスドメイン リクエストを防ぐために、JavaScript コードで CrossDomain オプションを false に変更してください。 。また、サーバー設定で指定されたオリジン (http://...) からのリクエストが許可されていることを確認してください。
以上がFlask アプリケーションの CORS 問題を解決する方法: なぜ「Access-Control-Allow-Origin」ヘッダーが必要なのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。