Axios 拦截器

拦截器作用

  拦截器可以在每一次请求或响应被thencatch处理之前拦截它们,并对其进行操作。利用拦截器可以统一对请求或响应做一些处理,比如统一为请求添加 token ,统一对响应的数据进行一些处理等

创建拦截器的方法

axios.interceptors.request.use()

  通过axios.interceptors.request.use(fun1, fun2)方法创建请求拦截器,它接受两个函数作为参数。
  fun1 接受一个自动传入的对象作为参数,该对象就是请求的配置对象。可以在 fun1 中对配置对象进行一些修改,从而影响请求操作。fun1 需要返回一个对象,即请求的配置对象。
  fun2 也接受一个自动传入的对象作为参数,该对象包含请求错误时的错误信息。可以在 fun2 中对其进行操作,从而对请求的错误信息进行统一的处理。

// 添加请求拦截器
axios.interceptors.request.use(
	config => {
	// fun1 发送请求之前做一些处理
        if (getToken()) {
            config.headers['Authorization'] = 'June ' + getToken() /
        }
        if (config.method == 'delete') {
            config.headers['Content-Type'] = 'application/x-www-form-urlencoded'
        }
        return config
    },
    error => {
    // fun2 对错误信息进行处理
        return Promise.reject(error)
    }
)

axios.interceptors.response.use()

  通过axios.interceptors.response.use(fun3, fun4)方法创建响应拦截器。该方法与请求拦截器基本一样,唯一的区别就是接受的参数对象不同,fun3 接受的参数对象是响应数据对象,fun4 接受的是响应错误对象。

axios.interceptors.response.use(
    response => {
        const code = response.status
        if (code < 200 || code > 300) {
            return Promise.reject(response);
        } else {
            return response.data
        }
    },
    error => {
    	return Promise.reject(error)
	}

  更多的,可以通过自定义 axios 实例添加拦截器。在实际项目中一般会用这种方法。

const service= axios.create({
    baseURL: process.env.BASE_API, 
    timeout: 5000 
});
service.interceptors.request.use(
	config => {
	// 发送请求之前做一些处理
        if (getToken()) {
            config.headers['Authorization'] = 'June ' + getToken() /
        }
        if (config.method == 'delete') {
            config.headers['Content-Type'] = 'application/x-www-form-urlencoded'
        }
        return config
    },
    error => {
    // 对错误信息进行处理
        return Promise.reject(error)
    }
);

使用方法

  在 request.js 文件导出 service对象。

export default service

  然后在其他文件中引入并使用,具体如下。

import request from '@/utils/request'
export const getData = params => {
  return request({ 
    url: '/api/xxx',
    method: 'GET',
    params: params
  })
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Axios 拦截器是一种在请求发送和响应返回之前,对请求和响应进行处理的机制。Axios 拦截器可以用于添加请求头、验证请求数据、对响应数据进行处理等场景。 Axios拦截器是基于 Promise 实现的,每个拦截器都是一个 Promise,其 resolve 函数接收一个 config 对象或 response 对象作为参数。Axios 支持两种类型的拦截器:请求拦截器和响应拦截器。 请求拦截器会在请求发送之前执行,响应拦截器会在响应返回之后执行。请求拦截器可以用于添加请求头、验证请求数据等操作,响应拦截器可以用于对响应数据进行处理。 Axios拦截器原理可以简单概括为: 1. 创建一个 Axios 实例,并设置默认配置。 2. 将请求和响应拦截器添加到实例中。 3. 当发送请求时,按照顺序执行请求拦截器中的代码。 4. 如果请求拦截器中发生了错误,Promise.reject() 方法会直接返回错误信息。 5. 如果请求拦截器中没有发生错误,Axios 会将最终的请求参数发送给服务器。 6. 当服务器返回响应时,Axios 会按照顺序执行响应拦截器中的代码。 7. 如果响应拦截器中发生了错误,Promise.reject() 方法会返回错误信息。 8. 如果响应拦截器中没有发生错误,Axios 会将最终的响应结果返回给调用者。 总之,Axios 拦截器的原理就是在请求和响应之间插入一些处理代码,以实现对请求和响应的自定义处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值