refactor: 重构异常处理
This commit is contained in:
parent
f0b6ce7d20
commit
ae43ffb94f
@ -8,7 +8,6 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { router } from '@/router'
|
|
||||||
import { useUserStore } from '@/store/modules/user'
|
import { useUserStore } from '@/store/modules/user'
|
||||||
import { IconExit } from '@/components/AppIcons'
|
import { IconExit } from '@/components/AppIcons'
|
||||||
import { renderIcon } from '@/utils/icon'
|
import { renderIcon } from '@/utils/icon'
|
||||||
@ -32,7 +31,6 @@ function handleSelect(key) {
|
|||||||
confirm() {
|
confirm() {
|
||||||
userStore.logout()
|
userStore.logout()
|
||||||
$message.success('已退出登录')
|
$message.success('已退出登录')
|
||||||
router.push({ path: '/login' })
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ import { useUserStore } from '@/store/modules/user'
|
|||||||
import { usePermissionStore } from '@/store/modules/permission'
|
import { usePermissionStore } from '@/store/modules/permission'
|
||||||
import { NOT_FOUND_ROUTE } from '@/router/routes'
|
import { NOT_FOUND_ROUTE } from '@/router/routes'
|
||||||
import { getToken, refreshAccessToken, removeToken } from '@/utils/token'
|
import { getToken, refreshAccessToken, removeToken } from '@/utils/token'
|
||||||
|
import { toLogin } from '@/utils/auth'
|
||||||
|
|
||||||
const WHITE_LIST = ['/login', '/redirect']
|
const WHITE_LIST = ['/login', '/redirect']
|
||||||
export function createPermissionGuard(router) {
|
export function createPermissionGuard(router) {
|
||||||
@ -18,19 +19,18 @@ export function createPermissionGuard(router) {
|
|||||||
refreshAccessToken()
|
refreshAccessToken()
|
||||||
next()
|
next()
|
||||||
} else {
|
} else {
|
||||||
try {
|
await userStore.getUserInfo().catch((error) => {
|
||||||
await userStore.getUserInfo()
|
removeToken()
|
||||||
|
toLogin()
|
||||||
|
$message.error(`【${error.code}】 ${error.message}`)
|
||||||
|
return
|
||||||
|
})
|
||||||
const accessRoutes = permissionStore.generateRoutes(userStore.role)
|
const accessRoutes = permissionStore.generateRoutes(userStore.role)
|
||||||
accessRoutes.forEach((route) => {
|
accessRoutes.forEach((route) => {
|
||||||
!router.hasRoute(route.name) && router.addRoute(route)
|
!router.hasRoute(route.name) && router.addRoute(route)
|
||||||
})
|
})
|
||||||
router.addRoute(NOT_FOUND_ROUTE)
|
router.addRoute(NOT_FOUND_ROUTE)
|
||||||
next({ ...to, replace: true })
|
next({ ...to, replace: true })
|
||||||
} catch (error) {
|
|
||||||
removeToken()
|
|
||||||
$message.error(error)
|
|
||||||
next({ path: '/login', query: { ...to.query, redirect: to.path } })
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { defineStore } from 'pinia'
|
import { defineStore } from 'pinia'
|
||||||
import { getUser } from '@/api/user'
|
import { getUser } from '@/api/user'
|
||||||
import { removeToken } from '@/utils/token'
|
import { removeToken } from '@/utils/token'
|
||||||
|
import { toLogin } from '@/utils/auth'
|
||||||
|
|
||||||
export const useUserStore = defineStore('user', {
|
export const useUserStore = defineStore('user', {
|
||||||
state() {
|
state() {
|
||||||
@ -31,14 +32,14 @@ export const useUserStore = defineStore('user', {
|
|||||||
this.userInfo = { id, name, avatar, role }
|
this.userInfo = { id, name, avatar, role }
|
||||||
return Promise.resolve(res.data)
|
return Promise.resolve(res.data)
|
||||||
} else {
|
} else {
|
||||||
return Promise.reject(res.message)
|
return Promise.reject(res)
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error(error)
|
return Promise.reject(error)
|
||||||
return Promise.reject(error.message)
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
logout() {
|
logout() {
|
||||||
|
toLogin()
|
||||||
removeToken()
|
removeToken()
|
||||||
this.userInfo = {}
|
this.userInfo = {}
|
||||||
},
|
},
|
||||||
|
8
src/utils/auth.js
Normal file
8
src/utils/auth.js
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import { router } from '@/router'
|
||||||
|
|
||||||
|
export function toLogin() {
|
||||||
|
router.replace({
|
||||||
|
path: '/login',
|
||||||
|
query: { ...router.currentRoute.query, redirect: router.currentRoute.path },
|
||||||
|
})
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
import { router } from '@/router'
|
import { getToken } from '@/utils/token'
|
||||||
import { getToken, removeToken } from '@/utils/token'
|
import { toLogin } from '@/utils/auth'
|
||||||
import { isNullOrUndef } from '../is'
|
import { isNullOrUndef } from '@/utils/is'
|
||||||
import { isWithoutToken } from './helpers'
|
import { isWithoutToken } from './helpers'
|
||||||
|
|
||||||
export function reqResolve(config) {
|
export function reqResolve(config) {
|
||||||
@ -15,27 +15,24 @@ export function reqResolve(config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const token = getToken()
|
const token = getToken()
|
||||||
if (token) {
|
if (!token) {
|
||||||
/**
|
|
||||||
* * jwt token
|
|
||||||
* ! 认证方案: Bearer
|
|
||||||
*/
|
|
||||||
if (!config.headers.Authorization) config.headers.Authorization = 'Bearer ' + token
|
|
||||||
|
|
||||||
return config
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* * 未登录或者token过期的情况下
|
* * 未登录或者token过期的情况下
|
||||||
* * 跳转登录页重新登录,携带当前路由及参数,登录成功会回到原来的页面
|
* * 跳转登录页重新登录,携带当前路由及参数,登录成功会回到原来的页面
|
||||||
*/
|
*/
|
||||||
const { currentRoute } = router
|
toLogin()
|
||||||
router.replace({
|
|
||||||
path: '/login',
|
|
||||||
query: { ...currentRoute.query, redirect: currentRoute.path },
|
|
||||||
})
|
|
||||||
return Promise.reject({ code: '-1', message: '未登录' })
|
return Promise.reject({ code: '-1', message: '未登录' })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* * jwt token
|
||||||
|
* ! 认证方案: Bearer
|
||||||
|
*/
|
||||||
|
config.headers.Authorization = config.headers.Authorization || 'Bearer ' + token
|
||||||
|
|
||||||
|
return config
|
||||||
|
}
|
||||||
|
|
||||||
export function reqReject(error) {
|
export function reqReject(error) {
|
||||||
return Promise.reject(error)
|
return Promise.reject(error)
|
||||||
}
|
}
|
||||||
@ -48,33 +45,27 @@ export function repReject(error) {
|
|||||||
let { code, message } = error.response?.data || {}
|
let { code, message } = error.response?.data || {}
|
||||||
if (isNullOrUndef(code)) {
|
if (isNullOrUndef(code)) {
|
||||||
// 未知错误
|
// 未知错误
|
||||||
console.error('【err】' + error)
|
code = -1
|
||||||
return Promise.reject({ code: -1, message: '接口异常!', error })
|
message = '接口异常!'
|
||||||
}
|
} else {
|
||||||
/**
|
/**
|
||||||
* TODO 此处可以根据后端返回的错误码自定义框架层面的错误处理
|
* TODO 此处可以根据后端返回的错误码自定义框架层面的错误处理
|
||||||
*/
|
*/
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case 401:
|
case 401:
|
||||||
message = message || '未登录'
|
message = message || '登录已过期'
|
||||||
// * 处理未登录的情况
|
|
||||||
removeToken()
|
|
||||||
const { currentRoute } = router
|
|
||||||
router.replace({
|
|
||||||
path: '/login',
|
|
||||||
query: { ...currentRoute.query, redirect: currentRoute.path },
|
|
||||||
})
|
|
||||||
break
|
break
|
||||||
case 403:
|
case 403:
|
||||||
message = message || '没有权限'
|
message = message || '没有权限'
|
||||||
// TODO 处理没有权限的情况
|
|
||||||
break
|
break
|
||||||
case 404:
|
case 404:
|
||||||
message = message || '资源或接口不存在'
|
message = message || '资源或接口不存在'
|
||||||
// TODO 处理资源或接口不存在的情况
|
|
||||||
break
|
break
|
||||||
default:
|
default:
|
||||||
|
message = message || '未知异常'
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
return Promise.resolve({ code, message })
|
}
|
||||||
|
console.error(`【${code}】 ${error}`)
|
||||||
|
return Promise.resolve({ code, message, error })
|
||||||
}
|
}
|
||||||
|
@ -24,14 +24,12 @@ export async function refreshAccessToken() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
const { time } = tokenItem
|
const { time } = tokenItem
|
||||||
if (new Date().getTime() - time > 1000 * 60 * 30) {
|
// token生成或者刷新后30分钟内不执行刷新
|
||||||
|
if (new Date().getTime() - time <= 1000 * 60 * 30) return
|
||||||
try {
|
try {
|
||||||
const res = await refreshToken()
|
const res = await refreshToken()
|
||||||
if (res.code === 0) {
|
if (res.code === 0) {
|
||||||
setToken(res.data.token)
|
setToken(res.data.token)
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {}
|
||||||
console.error(error)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user