Web アプリケーションを開発する場合、クロスドメインの問題は非常に一般的な問題です。ブラウザーの同一生成元ポリシー制限により、リクエストは現在のドメイン名で発行する必要があります。そうしないと制限されます。このため、異なるドメイン名にあるサーバー間のデータのやり取りが非常に困難になります。
この問題を解決するための一般的な方法は、サーバー側で対応する処理を実行すること、つまり、対応するクロスドメイン リクエストの応答ヘッダーを設定することです。 Flask-Cors は、クロスドメインの問題を解決するための優れた Python ライブラリです。
Flask-Cors とは何ですか?
Flask-Cors は Flask 拡張ライブラリのメンバーであり、その主な機能は、Flask アプリケーションにクロスドメイン リクエストを簡単に解決する機能を提供することです。これにより、Flask アプリケーションがクロスドメイン リクエストをサポートできるようになり、コード内で迅速に構成して呼び出すためのシンプルで使いやすい API が提供されます。
Flask-Cors の使用方法?
Flask-Cors を使用する前に、pip などのパッケージ管理ツールを通じて Flask-Cors ライブラリをインストールする必要があります。
次に、Flask アプリケーションで Flask-Cors を参照および構成するには、次のコードを使用できます。
from flask import Flask, jsonify from flask_cors import CORS app = Flask(__name__) # 允许跨域请求 CORS(app, resources=r'/*') # 路由 @app.route('/') def index(): return jsonify(message='Hello World!') # 启动服务器 if __name__ == '__main__': app.run()
Flask Configure を渡して、CORS クラスを使用して新しい CORS アプリケーション オブジェクトを作成します。アプリケーション インスタンス アプリと、クロスオリジン リクエストを許可するリソースのリスト。上記の例では、クロスオリジンリクエストを許可するようにすべてのリソースを設定しています。
上記のコードに加えて、Flask-Cors は、クロスドメイン要求応答ヘッダーをより柔軟に構成するための他の API も提供します。
たとえば、以下に示すように、特定の HTTP メソッドをサポートする CORS メソッドを使用することもできます。
from flask import Flask, jsonify from flask_cors import CORS app = Flask(__name__) # 设置只支持GET、HEAD和OPTIONS方法的跨域请求 cors = CORS(app, resources={r'/api/*': {'origins': '*'}, 'methods': ['GET', 'HEAD', 'OPTIONS']}) # 路由 @app.route('/api/test', methods=['GET']) def test(): return jsonify(message='Success!') # 启动服务器 if __name__ == '__main__': app.run()
ここでは、「/api/*」パスの下にあるすべてのリクエストを指定します。 GET、HEAD、OPTIONS の 3 つのメソッドのクロスドメイン応答に限定されます。
概要
Flask-Cors は、Python Web アプリケーションでクロスドメイン リクエストを解決するための非常に優れた拡張ライブラリです。特定の HTTP メソッドをサポートするクロスドメイン リクエストを提供するだけでなく、ユーザーが構成できる柔軟な API も多数備えています。 Flask-Cors を使用すると、クロスドメインの問題に対処する開発者の作業の困難さが大幅に軽減され、開発効率が向上します。
以上がFlask-Cors: Python Web アプリケーションのクロスドメインの問題を解決するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。