>웹 프론트엔드 >JS 튜토리얼 >nuxt 3의 인터셉터 및 로그를 사용한 사용자 정의 가져오기

nuxt 3의 인터셉터 및 로그를 사용한 사용자 정의 가져오기

PHPz
PHPz원래의
2024-08-30 19:01:32594검색

Nuxt를 사용해 본 적이 있다면 Fetch 컴포저블을 편리하게 사용하는 방법을 접했을 것입니다.

<script setup lang="ts">
const { data, status, error, refresh, clear } = await useFetch('/api/modules')
</script>

이렇게 하면 데이터 가져오기가 간편해집니다. 하지만 모두 인증이 필요한 API가 많다면 어떻게 될까요? 호출할 때마다 헤더를 추가하는 작업이 지루해집니다.

인터셉터를 입력하세요.

글로벌 인터셉터를 추가하기 위해 $fetch 주위에 맞춤 구성 가능한 래퍼를 구축합니다. 이는 API 호출에 지속적으로 인증 헤더가 필요할 때 특히 유용합니다.

기본적으로 Nuxt 3의 인증에 대한 이전 블로그 게시물과 동일한 프로젝트를 사용하겠습니다.

컴포저블 폴더 composables/useAuthFetch.ts에서 새 컴포저블을 만드는 것부터 시작하겠습니다

import type { UseFetchOptions } from 'nuxt/app';

const useAuthFetch = (url: string | (() => string), options: UseFetchOptions<null> = {}) => {
  const customFetch = $fetch.create({
    baseURL: 'https://dummyjson.com',
    onRequest({ options }) {
      const token = useCookie('token');
      if (token?.value) {
        console.log('[fetch request] Authorization header created');
        options.headers = options.headers || {};
        options.headers.Authorization = `Bearer ${token.value}`;
      }
    },
    onResponse({ response }) {
      console.info('onResponse ', {
        endpoint: response.url,
        status: response?.status,
      });
    },
    onResponseError({ response }) {
      const statusMessage = response?.status === 401 ? 'Unauthorized' : 'Response failed';
      console.error('onResponseError ', {
        endpoint: response.url,
        status: response?.status,
        statusMessage,
      });
      throw showError({
        statusCode: response?.status,
        statusMessage,
        fatal: true,
      });
    },
  });

  return useFetch(url, {
    ...options,
    $fetch: customFetch,
  });
};

export default useAuthFetch;

설명:

  • useAuthFetch: 맞춤 컴포저블입니다. useFetch와 동일한 인수를 사용합니다.
  • customFetch: 인터셉터를 사용하여 사용자 정의된 $fetch 인스턴스를 생성합니다.
  • baseURL: ofetch는 baseURL 옵션을 사용하여 ufo를 사용하여 baseURL에 대한 후행/선행 슬래시 및 쿼리 검색 매개변수 앞에 이를 추가합니다.
  • onRequest: 이 인터셉터는 모든 가져오기 호출 전에 실행됩니다. 쿠키에서 토큰을 가져와서 토큰이 있으면 Authorization 헤더를 추가합니다.
  • onResponse: 성공적인 가져오기 후에 실행되어 로깅을 제공합니다.
  • onResponseError: 가져오기 오류를 처리하고 세부 정보를 기록하며 showError를 사용하여 오류를 발생시킵니다(이를 정의했다고 가정).
  • return useFetch(...): 마지막으로 원래 useFetch를 호출하지만 실제 요청을 처리하기 위해 customFetch를 전달합니다.

여기에서 인터셉터에 대해 자세히 알아볼 수 있습니다

이제 인증된 API에서 데이터를 가져와야 할 때마다 useFetch 대신 useAuthFetch를 사용하면 인증이 원활하게 처리됩니다.

<template>
  <div v-if="user">Welcome back {{ user.email }}</div>
  <div v-else>loading...</div>
</template>
<script lang="ts" setup>
const { data: user } = await useAuthFetch('/auth/me');
</script>

Custom fetch with Interceptors and logs in nuxt 3

네트워크 호출을 검사하면 baseUrl이 정확하고 Authorization 헤더가 있는 것을 확인할 수 있습니다

벌채 반출

내 인터셉터에 애플리케이션에 Sentry와 같은 도구가 있는 경우 유용할 수 있는 몇 가지 로그를 추가했습니다.

Nuxt에 Sentry를 추가하는 방법: https://www.lichter.io/articles/nuxt3-sentry-recipe/

onRequest 인터셉터에서 sentry에 탐색경로를 추가할 수 있습니다

import * as Sentry from '@sentry/vue';

Sentry.addBreadcrumb({
        type: 'http',
        category: 'xhr',
        message: ``,
        data: {
          url: `${options.baseURL}${request}`,
        },
        level: 'info',
});

백엔드가 tracingId를 반환하는 경우 센트리가 포함된 태그와 컨텍스트를 추가하여 오류를 엔드포인트와 연결할 수도 있습니다.

onResponseError에 컨텍스트 이동 경로 및 태그를 추가할 수 있습니다

import * as Sentry from '@sentry/vue';

Sentry.setContext('http-error', {
   endpoint: response?.url,
   tracingId: 123,
   status: response?.status,
});
Sentry.addBreadcrumb({
 type: 'http',
 category: 'xhr',
 message: ``,
 data: {
  url: response?.url,
  status_code: response?.status,
 },
 level: 'error',
});
Sentry.setTag('tracingId', '123');

tracingId를 백엔드가 반환하는 사용자 정의 추적 로그로 교체하세요.

위 내용은 nuxt 3의 인터셉터 및 로그를 사용한 사용자 정의 가져오기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.