Axios的拦截器介绍:
- axios的拦截器原理如下:
axios拦截器
axios作为网络请求的第三方工具, 可以进行请求和响应的拦截
通过create创建了一个新的axios实例
// 创建了一个新的axios实例
const service = axios.create({
baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
// withCredentials: true, // send cookies when cross-domain requests
timeout: 5000 // 超时时间
})
请求拦截器
请求拦截器主要处理 token的统一注入问题
// 请求拦截器
service.interceptors.request.use(async config => {
// 请求接口 config是请求配置
// 取token
if (store.getters.token) {
// 只要有token 就要检查token时效性
if (CheckIsTimeOut()) {
// 继续?
await store.dispatch('user/lgout')
router.push('/login') // 跳到登录
return Promise.reject(new Error('您的token已经失效'))
}
// 如果存在token
config.headers.Authorization = `Bearer ${store.getters.token}`
// return config
}
// 这里一定要注意
// 一定要return config
return config
}, error => {
return Promise.reject(error)
})
处理axios的响应拦截器
- 响应拦截器主要处理 返回的
数据异常
和数据结构
问题
OK,除此之外,axios返回的数据中默认增加了一层
data的包裹
,我们需要在这里处理下
并且,如果执行失败,只是设置了success
为false
,并没有reject,我们需要一并处理下
// 响应拦截器
service.interceptors.response.use(response => {
// 成功执行
// axios默认加了一层data的包裹
const { success, message, data } = response.data
if (success) {
// 此时认为业务执行成功了
return data // 返回用户所需要的数据
} else {
// 当业务失败的时候
Message.error(message) // 提示消息
return Promise.reject(new Error(message))
}
}, async error => {
// error 有response对象 config
if (error.response && error.response.data && error.response.data.code === 10002) {
// 后端告诉前端token超时了
await store.dispatch('user/lgout') // 调用登出action
router.push('/login') // 跳到登录页
}
// 失败
// Message等同于 this.$message
Message.error(error.message) // 提示错误
// reject
return Promise.reject(error) // 传入一个错误的对象 就认为promise执行链 进入了catch
})
// 检查token是否过期
function CheckIsTimeOut() {
// 当前时间 - 存储的时间戳 > 时效性 false tr
return (Date.now() - getTimeStamp()) / 1000 > TimeOut
}
处理登录的返回结构问题
async login(context, data) {
// 经过响应拦截器的处理之后 这里的result实际上就是 token
const result = await login(data) // 实际上就是一个promise result就是执行的结果
// axios默认给数据加了一层data
// 表示登录接口调用成功 也就是意味着你的用户名和密码是正确的
// 现在有用户token
// actions 修改state 必须通过mutations
context.commit('setToken', result)
}
// 导出一个axios的实例 而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
const service = axios.create() // 创建一个axios的实例
service.interceptors.request.use() // 请求拦截器
service.interceptors.response.use() // 响应拦截器
export default service // 导出axios实例