Vuejs Router guard 工作意外
Vuejs Router guard works unexpected
我的路由器工作时出错,无法理解如何修复它。
这个全局路由器应该检查 jwt 令牌过期并处理路由。在添加 isActivated
帐户等功能之前一切正常。所以现在我需要检查用户是否有令牌以及用户帐户是否已激活。
1) 如果用户有令牌,它应该创建 next() 否则 next("/login") (重定向)
2) 如果用户有令牌但他的帐户尚未激活(第一次登录),它应该重定向到设置页面 next("/setup") 直到他提交一些信息。
所以这是我的守卫
router.beforeEach((to, from, next) => {
const token = localStorage.getItem("token");
const tokenExp = parseInt(localStorage.getItem("tokenExp"))
const isActivated = localStorage.getItem("isActivated")
const now = new Date().getTime() + 129600000
const requiresAuth = to.matched.some(record => record.meta.requiresAuth);
console.log("first")
if (requiresAuth && !token) {
next('/login');
} else if (requiresAuth && token) {
if (now > tokenExp) {
axios.post("/user/t/r", token)
.then(e => {
const token = e.headers['authorization'].replace("Bearer ", "");
localStorage.setItem("token", token);
localStorage.setItem("tokenExp", (new Date().getTime() + 172800000).toString())
if (isActivated === 'true') {
next()
} else {
next("/setup")
}
})
.catch(e => {
localStorage.removeItem("token")
localStorage.removeItem("tokenExp")
localStorage.removeItem("fullName")
localStorage.removeItem("role")
next('/login')
})
} else {
console.log("second")
if (isActivated === 'true') {
console.log("third")
next();
} else {
console.log("fourth")
next("/setup")
}
}
} else {
next();
}
})
这是我的console.log,登录时出错:
你正在无限重定向到 /setup,你的代码首先 运行 命中 "fourth" 然后将用户发送到 /setup,调用之前再次是 运行 并且你的无限循环开始。
如果用户已经在该页面上,您需要停止调用 next('/setup') 或 next('/login')。
您需要使用 router.currentRoute 来检查您是否打算重定向到他们已经打开的页面。
我的路由器工作时出错,无法理解如何修复它。
这个全局路由器应该检查 jwt 令牌过期并处理路由。在添加 isActivated
帐户等功能之前一切正常。所以现在我需要检查用户是否有令牌以及用户帐户是否已激活。
1) 如果用户有令牌,它应该创建 next() 否则 next("/login") (重定向)
2) 如果用户有令牌但他的帐户尚未激活(第一次登录),它应该重定向到设置页面 next("/setup") 直到他提交一些信息。
所以这是我的守卫
router.beforeEach((to, from, next) => {
const token = localStorage.getItem("token");
const tokenExp = parseInt(localStorage.getItem("tokenExp"))
const isActivated = localStorage.getItem("isActivated")
const now = new Date().getTime() + 129600000
const requiresAuth = to.matched.some(record => record.meta.requiresAuth);
console.log("first")
if (requiresAuth && !token) {
next('/login');
} else if (requiresAuth && token) {
if (now > tokenExp) {
axios.post("/user/t/r", token)
.then(e => {
const token = e.headers['authorization'].replace("Bearer ", "");
localStorage.setItem("token", token);
localStorage.setItem("tokenExp", (new Date().getTime() + 172800000).toString())
if (isActivated === 'true') {
next()
} else {
next("/setup")
}
})
.catch(e => {
localStorage.removeItem("token")
localStorage.removeItem("tokenExp")
localStorage.removeItem("fullName")
localStorage.removeItem("role")
next('/login')
})
} else {
console.log("second")
if (isActivated === 'true') {
console.log("third")
next();
} else {
console.log("fourth")
next("/setup")
}
}
} else {
next();
}
})
这是我的console.log,登录时出错:
你正在无限重定向到 /setup,你的代码首先 运行 命中 "fourth" 然后将用户发送到 /setup,调用之前再次是 运行 并且你的无限循环开始。
如果用户已经在该页面上,您需要停止调用 next('/setup') 或 next('/login')。
您需要使用 router.currentRoute 来检查您是否打算重定向到他们已经打开的页面。