针对token有效期较短,需要手动获取新token请求
import axios from 'axios'
service.interceptors.response.use(
response => {
if (response.data.code === 401) {
if (!isRefreshing) {
isRefreshing = true
let refreshToken= localStorage.getItem('refreshToken')
return refreshToken({ refreshToken , token: getToken() }).then(res => {
const { token } = res.data
setToken(token)
response.headers.Authorization = `${token}`
}).catch(err => {
removeToken()
router.push('/login')
return Promise.reject(err)
}).finally(() => {
isRefreshing = false
})
}
}
return response && response.data
},
(error) => {
Message.error(error.response.data.msg)
return Promise.reject(error)
}
)
同时发起两个或者两个以上的请求时,刷新token
import axios from 'axios'
let isRefreshing = false
let requests = []
service.interceptors.response.use(
response => {
if (response.data.code === 401) {
if (!isRefreshing) {
isRefreshing = true
let refreshToken= localStorage.getItem('refreshToken')
return refreshToken({ refreshToken, token: getToken() }).then(res => {
const { token } = res.data
setToken(token)
response.headers.Authorization = `${token}`
requests.forEach((cb) => cb(token))
requests = []
return service(response.config)
}).catch(err => {
removeToken()
router.push('/login')
return Promise.reject(err)
}).finally(() => {
isRefreshing = false
})
} else {
return new Promise(resolve => {
requests.push(token => {
response.headers.Authorization = `${token}`
resolve(service(response.config))
})
})
}
}
return response && response.data
},
(error) => {
Message.error(error.response.data.msg)
return Promise.reject(error)
}
)