如何做项目的权限控制?

91 篇文章 0 订阅
84 篇文章 4 订阅

(1)项目背景和问题
现有一个后台管理系统,共存在三种类型的人员:
普通用户:拥有查看、审核和下架商品的权限
管理员:普通用户权限 + 修改、删除商品的权限
超级管理员:管理员权限 + 添加、删除用户,绑定用户和角色权限
你来设计一个用户-角色-权限的模型,同时以Vue为例,说说前端如何实现?
(2)解决思路
应用业界经典的模型 RBAC(Role-based access control)来设计,也就是基于角色的访问控制。
RBAC是三个模型,两个关系:用户模型、角色模型和权限模型,用户和角色的关系、以及角色和权限的关系。

在这里插入图片描述

RBAC举例:
在这里插入图片描述

第一个表是用户模型,第二个表是角色模型,第三个表是权限模型。
第四个表是用户和角色的关系,第五个表是角色和权限的关系。
前端如何实现,拿 Vue 为例:
● 在路由 router.js 里面声明,从后端读取用户-角色-权限信息,通过 meta 标签来标示和记录。比如 meta: { roles: [ ‘R002’, ‘R003’] },表示该页面只有管理员或超级管理员角色才有资格进入。
● 。
● 读取 Vuex 的路由表信息,根据 Vuex 中可访问的路由,渲染侧边栏菜单组件。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值