vue手动刷新页面,axios拦截器不执行情况
需求: vue里面的拦截器在每次请求前添加上token(Authorization)问题:正常点击请求可以添加,一旦手动F5刷新页面,就直接没有进入拦截器分析原因: 需要把axios放外面单独封装,不放mian.js里面即可src下面新建文件夹utils,文件名称intercept.jsimport axios from 'axios'axios.defaults.withCredentials
·
- 需求: vue里面的拦截器在每次请求前添加上token(Authorization)
- 问题:正常点击请求可以添加,一旦手动F5刷新页面,就直接没有进入拦截器
- 分析原因: 需要把axios放外面单独封装,不放mian.js里面即可
src下面新建文件夹utils,文件名称intercept.js
import axios from 'axios'
axios.defaults.withCredentials = true
export const request = (config) => {
return axios(config)
}
// 请求前设置header
axios.interceptors.request.use(
config => {
if (localStorage.getItem('Authorization')) {
config.headers.Authorization = localStorage.getItem('Authorization')
}
return config
},
error => {
return Promise.reject(error)
})
// 请求完成后 拦截器
axios.interceptors.response.use(
response => {
console.log(response)
if (response.data.code === 1003) {
router.replace({
path: '/login'
})
localStorage.removeItem('Authorization')
}
return response
},
error => {
if (error.response) {
switch (error.response.status) {
case 401:
localStorage.removeItem('Authorization')
router.replace({
path: '/login',
query: {redirect: router.currentRoute.fullPath} // 登录成功后 跳转当前页面
})
}
}
}
)
// 这句一定要写
export default axios
然后在main.js引入,这里要注意import引入顺序,否则可能导致其他有问题。
更多推荐
已为社区贡献1条内容
所有评论(0)