页面 登录后页面权限控制

 

平安的方法

1.登录

  • 账户名,密码利用sm2进行加密
    • 登录后保存当前的Token 并调用后端接口查询当前账户的perms值

2.vue-Router中的index.js

{
    path:'/Dialog',
    name:'Dialog',
    redirect:'/Dialog/DialogResult',
    meta:{
        perm:'m:Dialog',//将权限值给后端
        title:'XXX',
    }
}

3.vue-Router中的permission.js 

//匹配权限
@params usersPerms 用户拥有的权限集合 后端返回 存在vuex中
@params routePerm router/index.js 中的路由表信息

function hasPermission(userPerms,routerPerm){
    //"*"表示所有资源
     if(userPerms.some(p=>p.val== "*")) return true
    //如果菜单路由上没有声明perm属性,默认显示该菜单,代表所有人都可访问
    if(!routerPerm) return true;
    //判断当前用户的资源权限中是否包含菜单路由中声明的权限
    return userPerms.some(p=>p.val==routerPerm)
}

router.beforeEach((to,from,next)=>{
    if(hasPermission(store.getters.perms,to.meta.perm)){
        next()
    }else{
        next({path:'/401',replace:true,query:{noGoBack:true}})
    }
})

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值