RBAC学习(一)
0.前提
:用户只有一个直属部门,但角色可以关联多个部门
有一种情况就不太适用:比如说地区经理是一个角色,张三是北京市地区经理,他在组织架构中的直属部门是华北大区,然后一个黑龙江的销售李四提一个折扣申请,按流程首先是地区经理来审批,但不能让张三审批,因为李四应该由黑龙江的地区经理来审批(角色再做一个细分?比如角色叫 北京市地区经理?或者地区和部门做切割?)
如果是一个用户可以选多个部门,那么在登录成功后需要选择以哪个部门成员来进入系统
1.若依设计
- 权限
- 菜单权限:与角色相关联,不同的角色展示不同的版块即页面
- 功能权限:是否允许特定的角色执行 增/删/改/查/导入/导出/上传/下载 功能
- 角色:一个用户可以有0-n个角色
- 与菜单关联,级联(如果选择了一个版块,那么该版块下的子页面及功能权限都有了)
- 数据权限
- 看所有
- 看自定义部门所有数据
- 看本部门所有数据
- 看本部门及子部门所有数据
- 只能看自己创建的数据
1.1 看所有
略
1.2 看自定义部门所有数据
先假设一个学生管理系统,组织架构如下:
此时有一个教导处主人的角色,那么他就能看到教导处、高一、高二、高三部门的数据
1.3 看本部门所有数据
班主任能看到班上所有学生的信息
1.4 看本部门及子部门所有数据
班主任能看到班上所有学生的信息以及所有学科成绩的信息
2.扩展
- 设置用户组属性,给一个用户组批量设置1-n个角色
- 角色组
- 角色和角色之间可能还有包含、互斥、交叉的关系
- 角色和角色之间是否有等级的划分?(类似于地区有层级,国家 > 大区 > 省/自治区/直辖市/特别行政区 > 市/区 > 区/县/市 > 乡/镇/村 等)
- 角色和数据表之间强关联,指定每个角色对一张表而言展示特定的列,比如说银行卡号、身份证号等涉及机密信息只允许特定的角色才能查看,如果是普通用户则不能查看或者进行数据脱敏(脱敏的话又涉及到以哪种规则来脱敏,比如说把卡号分为几部分,隐藏哪部分,用*或者中文乱码来代替等等)
- 部门设置直属领导,副领导,便于审批时使用
- 另外组织架构可能每个公司都不同,有些都是显示的是职能,比如销售部,财务部,行政部等,有些是人名+职能部门,人名一般在职能部门的上面,说明这些职能部门归该人统领,比如说高级副总裁张三(这是一个部门),下面有财务部,行政部等,那边张三手下的部门就需要像张三汇报
- 在若依这边,岗位也只是一个字段,没有体现其他作用。
- 岗位和职位的区别:一人一岗,职位是一对多,比如开发工程师这个职位有很多个。(感觉职位和角色有些类似)
- 参考:https://zhidao.baidu.com/question/2202380496130040148.html
若依这块是在vue里面编写的,判断角色hasRole('xx,yy'); 不利于后期修改
RBAC学习(一)的更多相关文章
- Django-CRM项目学习(六)-rbac模块(权限组件)
1.rbac权限组件 1.1 模板分析(五表结构) 1.2 模板构建 人物和角色进行多对多绑定,角色与权限进行多对多绑定.其中人物和角色的多对多绑定的操作可以避免相同的人物多重权限的操作. 1.3 数 ...
- kubernetes学习笔记之十:RBAC
第一章.RBAC介绍 在Kubernetes中,授权有ABAC(基于属性的访问控制).RBAC(基于角色的访问控制).Webhook.Node.AlwaysDeny(一直拒绝)和AlwaysAllow ...
- yii2 rbac权限管理学习笔记
下面介绍一个 yii2 的 Rbac 权限管理设置,闲话少说,直接上代码, 1.首先我们要在组件里面配置一下 Rbac ,如下所示(common/config/main-local.php或者main ...
- Kubernetes 学习16 RBAC
一.概述 1.前面讲过,kubernetes的授权也是基于插件来实现而且用户访问时某一次操作经由某一授权插件检查能通过后就不再经由其它插件检查.然后由准入控制插件再做进一步后续的准入控制检查.那么在他 ...
- Spring security OAuth2.0认证授权学习第二天(基础概念-RBAC)
RBAC 基于角色的访问控制 基于角色的访问控制用代码实现一下其实就是一个if的问题if(如果有角色1){ } 如果某个角色可以访问某个功能,当某一天其他的另一个角色也可以访问了,那么代码就需要变化, ...
- 学习RBAC 用户·角色·权限·表
- keystone命令与client接口学习
keystone学习 ------------------ Keystone(OpenStack Identity Service)是OpenStack框架中,负责身份验证.服务规则和服务令牌的功能, ...
- 《应用Yii1.1和PHP5进行敏捷Web开发》学习笔记(转)
学习地址为: http://www.yiibook.com/book/agile_web_application_development_with_yii1.1_and_php5 1.建立应用程序 ...
- 权限系统与RBAC模型概述
为了防止无良网站的爬虫抓取文章,特此标识,转载请注明文章出处.LaplaceDemon/SJQ. http://www.cnblogs.com/shijiaqi1066/p/3793894.html ...
- Oracle User Management FAQ翻译及学习笔记
转载 最近了解到AME 的东西,很迫切,先转载一篇 [@more@] Oracle User Management FAQ翻译及学习笔记 写在前面 本文主要是翻译的英文版的Oracle User Ma ...
随机推荐
- 050_Sublime For Salesforce
之前安装工具都是在网上找的文章,照着步骤一点点来的,最近电脑升级所以要重新安装,花了一个小时终于搞好了,虽然说现在插件已经不维护了,但我觉得目前的工具还是可以够我用的: 1.我之前用的是3083版本, ...
- 1.JavaScript的实现与由来
1.一个JavaScript由不同的部分组成 核心(ECMAScript)以下简称ES 文档对象模型(DOM) 浏览器对象模型(BOM) ES就是JavaScript的语法层面 而DOM则是浏览器解释 ...
- holiday05
第五天 cat cat会一次性显示所有的内容,适合查看 内容较少 的文本文件 选项 含义 -b 对非空输出行编号 -n 对输出的所有行编号 more more每次只显示一页内容,适合于查看 内容较多 ...
- 替代学习物联网-云服务-02阿里云MQTT
1.支付宝登录,进入物联网平台 https://iot.console.aliyun.com/product 2.新建产品 3.添加设备 4.设备连接参数 5.连接到阿里云
- python菜鸟学习: 8. 集合基础知识
# -*- coding: utf-8 -*-# 列表的特性:1,去重:2.关系测试list1 = [1, 4, 6, 8, 7, 8, 9]# 集合去重list2 = set(list1)print ...
- Spring RMI 介绍
Spring RMI RMI全称是Remote Method Invocation-远程方法调用,是纯Java的网络分布式应用系统的核心解决方案之一.Java RMI 支持存储于不同地址空间的程序级对 ...
- 2020-2021第一学期2024"DCDD"小组第十一周讨论
2020-2021第一学期"DCDD"第十一周讨论 小组名称:DCDD 小组成员:20202403孟凡斌.20202411陈书桓.20202416刘铭睿.20202420黄椿淇 照 ...
- Spring系列之基于 Java 的容器配置-9
目录 组合基于 Java 的配置 使用`@Import`注解 有条件地包含`@Configuration`类或`@Bean`方法 结合 Java 和 XML 配置 组合基于 Java 的配置 Spri ...
- 如何解决7z: command not found问题
7z是一种常见的压缩文件格式,如果你想要压缩或解压缩7z文件,你需要在你的系统上安装p7zip和p7zip-full.但是,有时候你会发现当你尝试运行7z或7za命令时,它会显示"bash: ...
- linux 文件系统和包管理工具rpm,yum
文件系统 1.什么是文件系统? 文件系统是一种存储和组织计算机中数据文件的机制或方法,他使得对计算机内的数据的存储.访问和查找变得更容易,简单. 文件系统落到计算机里其实就是一个应用软件 ext2 e ...