一、公司(Company)

  公司包含了体系结构集合与用户集合。 公司可以存在上下级关系,这种关系仅限于展现形式,公司与公司之间没有权限继承,也就是说在授权管理中公司之间全部是扁平关系。公司的属性有以下内容:

属性 类型
公司编码 字符串
公司名称 字符串
上级公司 公司
在上级公司下的排序 数字
下级公司 公司列表
下属体系结构 体系结构列表
其下用户 用户集合

二、体系结构(Architecture)

  体系结构是由一系列组织机构通过层次关系组成的一个树形结构。一个公司下可根据业务需求存在多个体系机构,如人事组织结构、办公组织结构、财务组织结构、项目组织结构等。 体系结构可以存在上下级关系,这种关系仅限于展现形式,体系结构与体系结构之间没有权限继承,也就是说在授权管理中同一公司下的体系结构之间全部是扁平关系。体系结构的属性有以下内容:

属性 类型
体系结构编码 字符串
体系结构名称 字符串
所属公司 公司
上级体系结构 体系结构
在上级体系结构下的排序 数字
下级体系结构 体系结构列表
组织结构根节点 组织机构

三、组织机构(Organization)

  组织机构是体系结构上的一个节点,每个节点都有一个上级节点和若干个下级节点。组织机构是有级别的,其级别是其所在体系结构的层次深度,如在一个体系结构下最根的组织机构节点是1级,1级下面的组织机构节点是2级,2级下面的组织机构节点是3级…… 组织机构有实机构与虚机构之分,实机构是真是存在的组织机构,而虚机构一般是为了收纳一些零散的组织机构或用户所建立的虚拟组织机构。实组织机构是有级别的,而且其下级组织机构的级别会加1;而虚机构是不占用级别的,其下级组织机构(实机构)会在其上级组织机构(实机构)的基础上加1。如1级的实机构“A”下有一个实机构“AA”和一个虚机构“Ab”,实机构“AA”的级别是2级,虚机构“Ab”是不占级别的,其下如果也有一个实机构“AbA”和一个虚机构“Abb”,那么实机构“AbA”是2级,而虚机构“Abb”不占级别,“Abb”下的实机构“AbbA”级别是2级,因为其上的两级都是虚机构都不占级别。组织机构的属性有以下内容:

属性 类型
组织机构编码 字符串
组织机构名称 字符串
组织机构类型 数字
所属公司 公司
所属体系结构 体系结构
上级组织机构 组织机构
在上级组织机构下的排序 数字
下级组织机构 组织机构列表
包含角色 角色列表

四、角色(Role)

  角色是组织机构节点下的对象。角色也是可以有上下级关系的,一个角色下可以再拆分出多个角色,在权限控制时下级角色是可以继承上级角色的权限的。角色可以挂接在某个组织机构下,也可以挂接在某个角色下,但角色下是不能再挂接组织机构节点的。角色的属性有以下内容:

属性 类型
角色编码 字符串
角色名称 字符串
所属公司 公司
所属体系结构 体系结构
所属组织机构 组织机构
它继承的角色 角色
在所属组织机构或它继承的角色下的排序 数字
继承它的角色 角色列表
被授予的用户 用户集合

五、用户(User)

  一个用户有且仅属于一个公司。如果两个公司下存在对应相同账号的用户,那么这是两个用户。一个用户可以存在在多个体系结构中,但在一个体系结构中只能属于一个组织机构。一个用户可以拥有一个体系结构下的多个角色。用户的属性有以下内容:

属性 类型
用户账号 帐号
显示名称 字符串
所属公司 公司
所直属的组织结构 (不同体系结构下)组织机构集合
所直接拥有的角色 角色集合

六、域(Domain)

  域是用来区分不同账号的一个集合。在一个域中是不允许存在相同的账号的。不同域可以有重名的账号,这些账号只是名称相同但不是同一账号,因为其所属不同的域。 域与公司是两个概念。公司下有该公司独立的组织机构与用户群体,而域下包含的是一套系统账号。我们常见的“网易通行证”、“Google帐号”、“QQ帐号”、“微博帐号”都属于域帐号,其对应的域可以分别是“163.com或126.com”、“gmail.com”、“qq”、“weibo”。而“万科”是个公司,其下有自己的组织架构与员工(用户)集合。

七、帐号(Account)

  帐号是用户在应用系统中的标识。帐号是由账号名称和所在域构成,其表示方式可以用“zhangsan@163.com”来表示,有时也用“qq\12345678”这种方式表示。 帐号与用户不是相同的概念。但是在我们要讨论的权限管理的场景下这两者是有关系的。比如,“万科”公司为了经营管理需要购置了一套XX管理系统,登录系统的用户主要就是从事相关业务的员工,并要求其员工(用户)都用邮箱帐号来作为XX管理系统的登录帐号。但是每个员工使用的邮箱都不相同,有用“163邮箱”的、有用“gmail邮箱”的、有用“qq邮箱”的…… 从功能角度来说,账号是用来做登录认证的,而用户是用来做授权的。帐号的属性有以下内容:

属性 类型
帐号 字符串
所属域
显示名称 字符串
密码 字符串
状态 数字

八、帐号关联(Relation)

  帐号关联是所属不同域的账号之间建立的关联关系,这种关联关系不是一对一的关联,而是多个账号间的关联。不同域的账号与账号之间一般是存在关联的。比如一个人的邮箱是“zhangsan@163.com”、QQ号码是“12345678”、微博帐号是“zhang_san”、手机号码是“13812345678”……这些都是所属不同域的不同账号。这些帐号都可以认证,其认证结果都可以验证这个人的身份。现在有一个论坛,这个论坛支持163邮箱、QQ、微博或手机登录。这个论坛用户可以绑定任何一类帐号,也可以同时绑定多种帐号,其中任一绑定的帐号认证通过都可以认证用户身份。那么“帐号关联”就是描述这些账号属于论坛同一个用户的这么一种关系。可以把“帐号关联”想象成一个“链”,这个“链”上把若干个账号串接了起来,这些帐号是有关联关系的。同一“链”中一个域只能存在一个账号,不存在两个账号所属同一个域的情况。“账号关联”的来源可能有多处,每一处来源都会形成一个“链”,比如在论坛A里记录了张三手机和邮箱的账号关联,社交平台B中记录了张三邮箱与QQ号的账号关联,这是两个“链”。

九、应用(Application)

  应用是为了实现某项业务的若干功能的集合,也是传统意义上的应用系统的概念。应用系统由若干功能组合,我们把功能可以当作是一种资源。应用的属性有以下内容:

属性 类型
应用ID 字符串
应用名称 字符串
应用密钥 字符串
功能集合 资源列表

十、资源(Resource)

  应用下有若干资源,有些资源是用户界面、有些资源是接口服务、有些资源是数据服务、有些资源是图片等静态资源……这些都是不同的资源类型。资源通过树形结构的形式进行排列和组织,并挂接在应用下面可供索引和使用。资源的属性有以下内容:

属性 类型
资源名称 字符串
资源路径 字符串
资源类型 字符串
所属应用 应用
上级资源 资源
上级资源路径下排序 数字
下级资源 资源列表

十一、权限对象(Authorization)

  权限对象是权限授予的记录。权限对象除了基本名称等信息外主要包括两部分:权限所有者和所有者被授予的权限。 权限所有者可以是若干个指定的用户、可以是若干个指定的组织机构、还可以是若干个指定的角色。 所有者被授予的权限一般是指定的资源的集合。权限对象的属性有以下内容:

属性 类型
权限对象编码 字符串
权限对象名称 字符串
权限所有者 用户集合&组织机构集合&角色集合
所拥有权限 资源集合

权限系统设计学习总结(1)——多租户的RBAC权限管理相关推荐

  1. 权限系统设计学习总结(2)——SAAS后台权限设计案例分析

    分享一个大神的人工智能教程.零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!点击浏览教程  saas平台由于其本身"按需购买"的特性,在设计规划权限时,需 ...

  2. 权限系统设计学习总结(4)—— SaaS 平台多租户模式下权限设计

    一.RBAC模型 1.1.概念 权限设计最常见的就是基于 RBAC 模型.而 RBAC 模型又有 RBAC0.RBAC1.RBAC2.RBAC3 等几种常见的模式.RBAC(Role-Based Ac ...

  3. oracle 创建角色 权限设置,[学习笔记] Oracle创建用户、分配权限、设置角色,

    [学习笔记] Oracle创建用户.分配权限.设置角色, 创建用户 create user student --用户名 identified by "123456" --密码 de ...

  4. 权限系统设计学习总结(3)——多账户的统一登录

    前言 多账户系统是指,在我们互联网应用当中,我们的应用会使用多个第三方账号进行登录,必须现在常用的APP(网易云音乐)登录方式包含:网易.微信.QQ.大部分的 App 都支持使用多个第三方账号进行登录 ...

  5. 权限系统设计及RBAC模型

    概述 对于一个企业级的平台或系统或站点,权限模块或系统是必不可少的.权限管控,即权力限制,不同的人由于拥有不同权力,他所看到的.能使用的东西不一样.对应到一个应用系统,其实就是一个用户可能拥有不同的数 ...

  6. RBAC权限实战项目-佟刚-专题视频课程

    RBAC权限实战项目-346人已学习 课程介绍         本视频讲授RBAC权限模型的设计.以及在项目中的应用 . 1. 使用Maven进行项目构建 . 2. 页面设计采用响应式前端框架Boot ...

  7. 基于RBAC权限管理实现的中小学成绩管理系统

    xjtuer最好不要抄,五次作业都是去年优秀作业,被老师逮住全给0分就得不偿失了,放在这里是给大家一个思路不用再去查找很多资料,了解之后再自己总结写一写 本文讲解的系统是中小学成绩管理系统,因为RBA ...

  8. [Abp 源码分析]多租户体系与权限验证

    点击上方蓝字关注我们 0.简介 承接上篇文章我们会在这篇文章详细解说一下 Abp 是如何结合 IPermissionChecker 与 IFeatureChecker 来实现一个完整的多租户系统的权限 ...

  9. 权限系统设计模型分析(DAC,MAC,RBAC,ABAC)

    此篇文章主要尝试将世面上现有的一些权限系统设计做一下简单的总结分析,个人水平有限,如有错误请不吝指出. 术语 这里对后面会用到的词汇做一个说明,老司机请直接翻到常见设计模式. 用户 发起操作的主体. ...

  10. 数字系统设计学习之出租车计价器设计

    前言 数字系统设计的大作业来了,用VHDL语言在实验板上实现一个出租车计价设计,有一些难度,大概花了几天时间,不过好在最后搞出来了,同时总结一下遇到的问题,为了排版整洁,源代码就放在最后放出了. 温馨 ...

最新文章

  1. MultiResUNet笔记
  2. python编写的软件界面-用Python写一个带图形界面的文件压缩软件
  3. 广义逆高斯分布及推广(To be continued)
  4. 6月 Python 开源项目 Top10,还不收藏~
  5. oracle树结构统计,ORACLE 递归树型结构统计汇总
  6. DataGridView常用操作
  7. 山西省行政村边界数据/乡镇街道边界数据/行政区划边界分布
  8. 搜狗收录提交方法搜狗收录方法
  9. android手写计算器,MyScript Calculator(高级手写计算器) V1.2.2.479 安卓版
  10. 虚拟机安装ubuntu怎么全屏_ubuntu虚拟机怎么设置全屏显示?
  11. 帆软报表 异常汇总及方案.
  12. 最牛叉的街机游戏合集 模拟器
  13. 苹果7p最佳系统版本_苹果代码中发现, iPhone12 刘海没了!
  14. 关于数据库账号和密码加密问题
  15. 搭建自己的在线IDE
  16. Spring Boot 3.0 正式发布,这份升级指南必须收藏
  17. 山东大学往年c语言期末试题及答案,山东大学历年C语言题库.doc
  18. 基于GAN的小目标检测算法总结(1)——Perpetual GAN
  19. sqlyog修改背景颜色成护眼色
  20. 最方便正则验证手机号

热门文章

  1. 在win 10系统下安装VS 2015
  2. 需求文档:自营电商后台管理系统
  3. 保留地址就是私有地址吗?
  4. 装修软件平台开发的优势
  5. 微信小程序地图与位置相关操作
  6. JXLS (Excel 导出工具使用)
  7. 谷歌Chrome浏览器离线安装包
  8. FDDB人脸检测测评数据集介绍
  9. 封装继承多态还是封装抽象继承多态
  10. python的源代码下载_官方下载python源码,编译linux版本的python