axios全局和请求拦截器封装(单独拦截器)

目录

主要代码已打注释,总代码包含全局和单独请求拦截器。封装报错解释可参考其他文章

axios全局拦截器:

 单独拦截器:

总代码: 


主要代码已打注释,总代码包含全局和单独请求拦截器。封装报错解释可参考其他文章
axios全局拦截器:

request/index

import axios from 'axios'
import type { AxiosInstance, AxiosRequestConfig } from 'axios'
import type { HYRequestInterceptors, HYRequestConfig } from './type'

class HYRequest {
  instance: AxiosInstance
  interceptors?: HYRequestInterceptors

  constructor(config: HYRequestConfig) {
    this.instance = axios.create(config)
    this.interceptors = config.interceptors

    // 从config中取出的拦截器是对应的实例的拦截器
    this.instance.interceptors.request.use(
      this.interceptors?.requestInterceptor,
      this.interceptors?.requestInterceptorCatch
    )

    this.instance.interceptors.response.use(
      this.interceptors?.responseInterceptor,
      this.interceptors?.responseInterceptorCatch
    )

    // 添加所有的实例都有的拦截器
    this.instance.interceptors.request.use(
      (config) => {
        console.log('所有实例都有的拦截器:请求拦截成功')
        return config
      },
      (err) => {
        console.log('所有实例都有的拦截器:请求拦截失败')
        return err
      }
    )

    this.instance.interceptors.response.use(
      (res) => {
        console.log('所有实例都有的拦截器:响应成功拦截')
        return res
      },
      (err) => {
        console.log('所有实例都有的拦截器:响应失败拦截')
        return err
      }
    )
  }

  request(config: AxiosRequestConfig) {
    this.instance.request(config).then((res) => {
      console.log(res)
    })
  }
}

export default HYRequest

request/type

import {
  InternalAxiosRequestConfig,
  AxiosResponse,
  AxiosRequestConfig
} from 'axios'
export interface HYRequestInterceptors {
  requestInterceptor?: (
    config: InternalAxiosRequestConfig
  ) => InternalAxiosRequestConfig
  requestInterceptorCatch?: (error: any) => any
  responseInterceptor?: (res: AxiosResponse) => AxiosResponse
  responseInterceptorCatch?: (error: any) => any
}

export interface HYRequestConfig extends AxiosRequestConfig {
  interceptors?: HYRequestInterceptors
}
 单独拦截器:

刚开始因为InternalAxiosRequestConfigAxiosRequestConfig类型请求头不匹配。在传输时添加一个匹配的头就可以了

总代码: 
import axios from 'axios'
import type { AxiosInstance } from 'axios'
import type { HYRequestInterceptors, HYRequestConfig } from './type'

class HYRequest {
  instance: AxiosInstance
  interceptors?: HYRequestInterceptors

  constructor(config: HYRequestConfig) {
    this.instance = axios.create(config)
    this.interceptors = config.interceptors

    // 从config中取出的拦截器是对应的实例的拦截器
    this.instance.interceptors.request.use(
      this.interceptors?.requestInterceptor,
      this.interceptors?.requestInterceptorCatch
    )

    this.instance.interceptors.response.use(
      this.interceptors?.responseInterceptor,
      this.interceptors?.responseInterceptorCatch
    )

    // 添加所有的实例都有的拦截器
    this.instance.interceptors.request.use(
      (config) => {
        console.log('所有实例都有的拦截器:请求拦截成功')
        return config
      },
      (err) => {
        console.log('所有实例都有的拦截器:请求拦截失败')
        return err
      }
    )

    this.instance.interceptors.response.use(
      (res) => {
        console.log('所有实例都有的拦截器:响应成功拦截')
        return res
      },
      (err) => {
        console.log('所有实例都有的拦截器:响应失败拦截')
        return err
      }
    )
  }

  request(config: HYRequestConfig) {
    if (config.interceptors?.requestInterceptor) {
      config = config.interceptors.requestInterceptor(config)
    }
    this.instance.request(config).then((res) => {
      if (config.interceptors?.responseInterceptor) {
        res = config.interceptors.responseInterceptor(res)
      }
      console.log(res)
    })
  }
}

export default HYRequest

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
拦截器axios中非常重要的功能之一,它允许我们在发送请求或响应之前对其进行拦截和处理。拦截器可以用来在请求发送前添加公共的请求头、请求超时处理、错误处理以及对响应数据进行统一处理等等。 在axios中,我们可以使用`axios.interceptors`来添加拦截器。具体的拦截器有两种类型,一种是请求拦截器,另一种是响应拦截器。 1. 请求拦截器请求拦截器可以在发送请求之前对请求进行处理,比如添加公共的请求头。你可以使用`axios.interceptors.request.use()`方法来添加请求拦截器。下面是一个示例代码: ``` axios.interceptors.request.use(config => { // 在发送请求之前做些什么 config.headers.Authorization = 'Bearer ' + getToken(); // 添加请求头 return config; }, error => { // 对请求错误做些什么 return Promise.reject(error); }); ``` 2. 响应拦截器: 响应拦截器可以在接收到响应之后对其进行处理,比如对响应数据进行统一处理或者错误处理。你可以使用`axios.interceptors.response.use()`方法来添加响应拦截器。下面是一个示例代码: ``` axios.interceptors.response.use(response => { // 对响应数据做些什么 if (response.data.code !== 200) { Message.error(response.data.message); // 统一处理错误信息 } return response; }, error => { // 对响应错误做些什么 return Promise.reject(error); }); ``` 以上就是axios拦截器的基本使用方法。通过使用拦截器,我们可以对请求和响应进行全局的处理,提高代码的复用性和可维护性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值