ホームページ >ウェブフロントエンド >Vue.js >axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

藏色散人
藏色散人転載
2022-08-10 09:55:353569ブラウズ

1. axios のグローバル構成

1. axios のグローバル構成理由

実際のプロジェクト開発では、axios が開始するほぼすべてのコンポーネントが使用されます。データリクエスト。このとき、次の 2 つの問題が発生します。

① 各コンポーネントで axios (肥大化したコード) をインポートする必要がある

② リクエストを送信するたびに、完全な情報を入力する必要があるリクエスト パス (後のメンテナンスに役立ちません) [関連する推奨事項: vue.js ビデオ チュートリアル ]

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

##2. グローバル設定 axios の方法

main.js エントリ ファイルで、app.config.globalProperties を通じて axios をグローバルにマウントします。サンプル コードは次のとおりです。

#3. vue2 プロジェクトでの axios のグローバル設定axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

メインの Vue コンストラクターのプロトタイプ プロトタイプ オブジェクトを通じて、axios をグローバルに設定する必要があります。 js エントリ ファイル

2. axios インターセプターaxios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

#1. インターセプターとは

インターセプター (英語: Interceptors) は、ajax リクエストが行われ、応答が受信されるたびに自動的にトリガーされます。

2. リクエスト インターセプターの設定axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

axios.interceptors.request.use(成功したコールバック、失敗コールバック) リクエスト インターセプターを構成できます。サンプル コードは次のとおりです。

##2.1 リクエスト インターセプター – トークン認証

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

##2.2 リクエスト インターセプター – 読み込みエフェクトの表示

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)要素 ui

# によって提供される読み込みエフェクト コンポーネントの助けを借りて

##3. レスポンス インターセプターの設定

レスポンス インターセプターは、axios.interceptors.response.use (成功したコールバック、失敗したコールバック) を通じて設定できます。 。サンプル コードは次のとおりです。 axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

##読み込み効果を示す実際の例:

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

#3. プロキシ クロスドメイン プロキシ

1. インターフェイスのクロスドメインの問題

クロスドメインの問題を解決するaxios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

#1)、Cors (最も標準的な処理) では、フロントエンド担当者が処理を行う必要はなく、サーバーを作成する人だけが応答を返すときにいくつかの特別な応答ヘッダーを追加する必要があります。サーバー内
2)、Jsonp 最も独創的な解決策は、外部リソースを導入するときに同一オリジン ポリシーによって制限されないように script タグの src 属性を使用することです。この機能は開発ではほとんど使用されませんフロントエンドとバックエンドの担当者が一緒に完了する必要があり、解決できるのは get リクエストのみであるためです。クロスドメインの問題

3)、プロキシ サーバー

プロキシ サーバーも同様です。サーバーです。そのポート番号は私たちのものと一致しています。2 つのサーバー間の通信は、同一生成元ポリシーの制限に準拠していません。それだけです。これにより、クロスドメインの問題を解決できます。したがって、リクエストを送信するときは、ポート番号また、8080


vue プロジェクトが実行されるアドレス: http://localhost:8080/

API インターフェイスが実行されるアドレス: http://www.escook. cn/api/users

現在の API インターフェイスでは CORS クロスドメイン リソース共有が有効になっていないため、デフォルトでは、上記のインターフェイスは正常にリクエストできません。


2. プロキシを通じてインターフェイスのクロスドメインの問題を解決する

vue-cli を通じて作成されたプロジェクトでインターフェイスに関するクロスドメインの問題が発生した場合、プロキシを通じて解決できます:

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

① axios のリクエスト ルート パスを vue プロジェクトの実行アドレスに設定します (インターフェイス リクエストはドメインを越えなくなりました)

② vue プロジェクトは、要求されたインターフェイスが存在しないことを検出し、リクエストをプロキシ エージェントに転送します

#③ プロキシはリクエストのルート パスを devServer.proxy 属性の値に置き換え、実際のデータ リクエストを開始します

④ プロキシがリクエストを転送する 受信したデータが axios に転送される

##3. プロジェクトでプロキシを設定する

##ステップ 1. main.js エントリ ファイルで、 axios のルート パスを現在の Web プロジェクトにリクエストします。 ルート パス:


axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

ステップ 2、vue を作成します。プロジェクトのルート ディレクトリにある config.js 構成ファイルを開き、次の構成を宣言します:


axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

##① devServer.proxy 関数によって提供されるプロキシ。開発およびデバッグ段階でのみ有効です。

② プロジェクトがオンラインで起動されるときも、API インターフェイス サーバーで CORS クロスドメイン リソース共有を有効にする必要があります。

利用方法 1 プロキシサーバーを設定する 欠点は 2 つあります :

1. プロキシサーバーを使用するかどうかを柔軟に制御できない

パブリックフォルダーは、 8080 サーバーのルート パス (8080 サーバーにあるものはパブリック ファイルによって異なります。フォルダーにあるもの) 要求されたリソース 8080 自体がそれを持っている場合、要求は 5000 サーバーに転送されません


2. 複数のプロキシを構成することはできず、リクエストは 5000 サーバーにのみ転送できます

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)方法 2 を使用して、プロキシ サーバーを開く '/api' リクエスト プレフィックス

機能: ローカル リクエストがプロキシに送信されるとき サーバーを使用する場合、プロキシ サーバーはリクエストのプレフィックスが '/api' であるかどうかを判断します。であればリクエストを送信します(リクエストを5000に転送します)。そうでない場合はリクエストは送信されません。プロキシサーバーを使用するかどうかを柔軟に制御できます(「/api」)。固定値ではなく、任意の値を使用できます。 '/hah' などとしてカスタマイズ)

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)プレフィックスの搬送位置: ポート番号の直後

#これを直接リクエストすると、リクエストを 5050 サーバーに送信するときに、まだリクエストが行われないため、404 エラーが発生します。 /api/ Students を伝送します。5050 サーバーには Student はありますが、/api/students はありません。axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)

この構成を追加すると、プロキシ サーバーが 5050 サーバーにリクエストを送信するときに、/students のみが送信されるようになります。データを取得します



ws ロール: websocket のサポートに使用されます

axios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)changeOrigin: (使用

changeOrigin: true の場合、プロキシ サーバーは、5050 サーバーでもあることを示します。

changeOrigin: false の場合、プロキシ サーバーは、5050 サーバーでもあることを示します。これは 8080 サーバーです。

場合によっては 5050 サーバーが使用します。いくつかの制限があるため、この構成項目は true に設定するのが最適です。

wsとchangeOriginが書かれていない場合、デフォルト値もtrueになります(reactでfalseと書かれていない場合)

以上がaxios のグローバル構成、インターセプター、プロキシのクロスドメイン プロキシの詳細な分析 (画像とテキスト)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjianshu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。