Vue3 axios响应拦截器处理接口返回401未登录跳转登录页
【代码】Vue3 axios响应拦截器处理接口返回未登录返回登录页。
·
问题:
- 在
asiox使用useRouter实例化创建router路由对象,在response响应拦截器里为undefined访问不到 - 使用
window.location.href = '/login'跳转登录页, 本地可以正常跳转,测试环境页面会显示 not found 404, 测试环境访问地址大概是这样ip:8080/pm/#/login, 本地没有/pm
解决方案:
- 在
main.ts文件有引入router并app.use(router)注入路由 - 这个
router在axios文件响应拦截里也可以访问到router对象 - 这样就可以愉快的用
router.push('/login')
原因:useRouter、useRoute、useStore 是要随着 setup 语法糖一起解析, 会有一个 runtime 运行时的过程,所以无法直接使用
代码示例
router文件
import service from '@/views/service'
import { createRouter, createWebHashHistory, createWebHistory } from 'vue-router'
const router = createRouter({
// history: createWebHistory(),
history: createWebHashHistory(),
routes: [
{
path: '/',
component: () => import('@/home/index.vue'),
},
{
path: '/login',
name: '/login',
component: () => import('@/views/login/index.vue'),
},
],
})
export default router
axios文件
import axios from 'axios'
import { ElMessage } from 'element-plus'
// 引入定义的 router 实例
import router from '../router'
const request: any = axios.create({
baseURL: '/api',
timeout: 600000,
})
function redirectLogin() {
router?.push('/login')
}
request.interceptors.response.use(
(response: any) => {
// 未登录回到登录页
if (response.data?.code === '401') {
return router?.push('/login')
}
if (response.data.code !== '200') {
ElMessage.error(response.data.msg)
return Promise.reject(response.data)
} else {
return response.data.data
}
},
(error: any) => {
return Promise.reject(error)
}
)
export default request
更多推荐



所有评论(0)