当前位置:   article > 正文

Vue前端 更具router.js 中的meta的roles实现路由卫士,实现权限判断。_router.js能做判断吗

router.js能做判断吗

参考了之篇文章

1、我在登陆时获取到登录用户的角色名roles,并存入sessionStorage中,具体是在login页面实现,还是在menu页面实现都可以。在menu页面实现,可以显得登陆快一些。
在这里插入图片描述
2、编写router.js,注意,一个用户可能有多个角色。

//以下为一个路由例子
{
	path: "/xxxx/xxxx",
	component: () => import('@/components/xxx'),
	name: "随便取个名字",
	meta: {
		roles:['角色1','角色2','角色3']
	}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
//在路由跳转前进行判断
router.beforeEach((to,from,next) => {
    //设置直接通过的路由地址
	if(to.path === "/" || to.path === "/login" || to.path === "/menu") {
		next();
	}else {
		const tokenStr = localStorage.getItem("token")
		//如果token没有了,直接返回登录界面,即长时间没有操作。
		if (!tokenStr) {
			return next("/login");
		}else {
			//数据库中的roles以“角色1,角色2,角色3”的字符串存储,使用split分割成数组
			const roles = sessionStorage.getItem("userRole").split(",")
			//这里表示路由设置的roles中内有内容,我们没有设置权限,那么直接放行。
			if(to.meta.roles.length === 0){
				next()
			}else{
				//这里表示做循环,只要有一个满足就可以跳转了。
				for (let i = 0; i < to.meta.roles.length; i++){
				     //roles中有一个与用于的角色匹配就行
					if(roles.includes(to.meta.roles[i])){
						next()
					}
				}
			}
		}
	}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

这里有个bug

我们的roles存在sessionStorage中,关闭那个网页就没有了。但是token还在,就会产生报错,我们做一下判断最好。或者把roles也存在localstorage中

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/blog/article/detail/58856
推荐阅读
相关标签
  

闽ICP备14008679号