Nuxt を使用したことがある場合は、おそらく便利な useFetch コンポーザブルに遭遇したことがあるでしょう。
これによりデータの取得が簡素化されますが、すべて認証を必要とする API が多数ある場合はどうなるでしょうか? 各呼び出しにヘッダーを追加するのはすぐに面倒になってしまいます。
インターセプターを入力します。
グローバル インターセプターを追加するには、$fetch の周りにカスタムのコンポーザブル ラッパーを構築します。これは、API 呼び出しで常に認証ヘッダーが必要な場合に特に役立ちます。
基礎として、Nuxt 3 での認証に関する以前のブログ投稿と同じプロジェクトを使用してみましょう。
まず、コンポーザブル フォルダー composables/useAuthFetch.ts の下に新しいコンポーザブルを作成しましょう
説明:
インターセプターの詳細については、こちらをご覧ください
これで、認証された API からデータをフェッチする必要があるときはいつでも、useFetch の代わりに useAuthFetch を使用するだけで、認証がシームレスに処理されます。
ネットワーク呼び出しを検査すると、baseUrl が正しく、Authorization ヘッダーが存在することがわかります
私のインターセプターには、アプリケーションに Sentry などのツールがある場合に役立つログをいくつか追加しました。
Nuxt に Sentry を追加する方法: https://www.lichter.io/articles/nuxt3-sentry-recipe/
onRequest インターセプターで、パンくずリストを Sentry に追加できます
バックエンドが tracingId を返す場合は、セントリーのタグとコンテキストを追加して、エラーをエンドポイントにリンクすることもできます
ResponseError では、コンテキストのブレッドクラムとタグを追加できます
tracingId をバックエンドが返すカスタム トレース ログに置き換えます
以上がnuxt 3 のインターセプターとログを使用したカスタムフェッチの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。