`
addday
  • 浏览: 68210 次
  • 性别: Icon_minigender_1
  • 来自: 湖南
社区版块
存档分类
最新评论

RBAC 权限 基于角色的权限控制

阅读更多

我感觉这篇文章描述的不错,也不知道是谁的作者,放到这里来了~~

角色访问控制(RBAC )引入了Role的概念,目的是为了隔离User(即动作主体,Subject)与Privilege(权限,表示对Resource的一个操作,即Operation+Resource)。
Role作为一个用户(User)与权限(Privilege)的代理层,解耦了权限和用户的关系,所有的授权应该给予Role而不是直接给User或 Group。Privilege是权限颗粒,由Operation和Resource组成,表示对Resource的一个Operation。例如,对于 新闻的删除操作。Role-Privilege是many-to-many的关系,这就是权限的核心。

基于角色的访问控制方法(RBAC )的显著的两大特征是:1.由于角色/权限之间的变化比角色/用户关系之间的变化相对要慢得多,减小了授权管理的复杂性,降低管理开销。2.灵活地支持企业的安全策略,并对企业的变化有很大的伸缩性。

RBAC 基本概念:

RBAC 认为权限授权实际上是Who、What、How的问题。在RBAC 模型中,who、what、how构成了访问权限三元组,也就是“Who对What(Which)进行How的操作”。

Who:权限的拥用者或主体(如Principal、User、Group、Role、Actor等等)

What:权限针对的对象或资源(Resource、Class)。

How:具体的权限(Privilege,正向授权与负向授权)。

Operator:操作。表明对What的How操作。也就是Privilege+Resource

Role:角色,一定数量的权限的集合。权限分配的单位与载体,目的是隔离User与Privilege的逻辑关系.

Group:用户组,权限分配的单位与载体。权限不考虑分配给特定的用户而给组。组可以包括组(以实现权限的继承),也可以包含用户,组内用户继承组的权限。User与Group是多对多的关系。Group可以层次化,以满足不同层级权限控制的要求。

RBAC 的关注点在于Role 和User, Permission的关系。称为User assignment(UA)和Permission assignment(PA).关系的左右两边都是Many-to-Many关系。就是user可以有多个role,role可以包括多个user。

凡是用过RDBMS都知道,n:m 的关系需要一个中间表来保存两个表的关系。这UA和PA就相当于中间表。事实上,整个RBAC 都是基于关系模型。

Session在RBAC 中是比较隐晦的一个元素。标准上说:每个Session是一个映射,一个用户到多个role的映射。当一个用户激活他所有角色的一个子集的时候,建立一个session。每个Session和单个的user关联,并且每个User可以关联到一或多个Session.

RBAC 系统中,User实际上是在扮演角色(Role),可以用Actor来取代User,这个想法来自于Business Modeling With UML一书Actor-Role模式。考虑到多人可以有相同权限,RBAC 引入了Group的概念。Group同样也看作是Actor。而User的概念就具象到一个人。

这里的Group和GBAC(Group-Based Access Control)中的Group(组)不同。GBAC多用于操作系统中。其中的Group直接和权限相关联,实际上RBAC 也借鉴了一些GBAC的概念。

Group和User都和组织机构有关,但不是组织机构。二者在概念上是不同的。组织机构是物理存在的公司结构的抽象模型,包括部门,人,职位等等,而权限模型是对抽象概念描述。组织结构一般用Martin fowler的Party或责任模式来建模。

Party模式中的Person和User的关系,是每个Person可以对应到一个User,但可能不是所有的User都有对应的Person。 Party中的部门Department或组织Organization,都可以对应到Group。反之Group未必对应一个实际的机构。例如,可以有 副经理这个Group,这是多人有相同职责。

引入Group这个概念,除了用来解决多人相同角色问题外,还用以解决组织机构的另一种授权问题:例如,A部门的新闻我希望所有的A部门的人都能看。有了这样一个A部门对应的Group,就可直接授权给这个Group。

分享到:
评论
4 楼 addday 2012-12-16  
用户组与角色组合,才能做到真正的业务系统的权限控制。
3 楼 addday 2012-12-16  
用户组是用来指定业务范围的,角色是有继承,但它是用来定义功能范围的。
2 楼 qepwqnp 2010-05-20  
楼上正解!!!
1 楼 timshaw9791 2009-10-07  
我觉得group有点被你滥用了。role本身就有继承的概念,group应该尽量不继承,而以一种扁平的方式来使用。如果group出现了多次继承,我觉得说明整个权限划分可能出现了问题。
再者,对于role和group,预期说是继承还不如说是组合,因为他们大多数时候仅仅是为了授权方便而使用的,相比于语义上的继承,更多的一种实现级别的继承。就好比我们java中推崇使用组合少用继承。

相关推荐

    RBAC(基于角色权限管理的说明)

    ### RBAC(基于角色权限管理)深度解析 #### 引言 基于角色的访问控制(Role-Based Access Control,简称RBAC)作为一种先进的访问控制机制,近年来在企业和教育机构的资源管理中得到了广泛应用。RBAC的核心理念是将...

    基于Django和Vue的RBAC权限控制后台管理系统源码

    项目概述:本源码为基于角色基础访问控制(RBAC)模型的中小型应用开发平台,采用前后端分离架构。后端基于Python的Django框架和Django REST Framework实现,前端则使用Vue.js配合ElementUI进行构建。移动端支持通过...

    【参考】RBAC模型基于角色-功能-资源的权限控制模型

    在众多的权限管理模型中,基于角色的访问控制(Role-Based Access Control,简称RBAC)因其灵活性和易用性而被广泛采用。本文将详细介绍基于RBAC模型的权限控制设计,并探讨其在实际项目中的应用。 #### 二、RBAC...

    ThinkPHP的RBAC,基于角色的权限控制-下载地址+2011年最新.txt

    根据给定文件的信息,我们可以提炼出关于ThinkPHP的RBAC(基于角色的访问控制)的知识点,尽管部分内容似乎与主题不完全相关,但从标题、描述和部分提供的内容中,我们仍能归纳出以下要点。 ### ThinkPHP的RBAC概念...

    RBAC模型基于角色-功能-资源的权限控制模型

    ### RBAC模型基于角色-功能-资源的权限控制模型 #### 概述 角色-Based Access Control(RBAC),即基于角色的访问控制模型,是一种广泛应用于企业级软件系统的权限管理体系。它通过为用户分配角色来简化权限管理...

    FastAPI+Vue3,RBAC权限管理,实现 菜单、路由、按钮、接口 权限控制;笔记ht-mini-rbac.zip

    本笔记主要探讨了如何利用FastAPI和Vue3框架实现基于角色的访问控制(Role-Based Access Control,简称RBAC)来管理菜单、路由、按钮以及接口的权限。我们将深入探讨FastAPI的特性、Vue3的优势以及RBAC的原理,以及...

    RBAC模型基于角色-功能-资源的权限控制模型.pdf

    基于角色-功能-资源的权限控制模型是对RBAC模型的一种深入拓展,它将权限管理细分为角色、功能和资源三个关键部分,使得权限控制更加精细化和灵活。 在这个模型中,角色是指系统中特定的职位或者功能性的职责;功能...

    基于django的RBAC权限控制模块

    **基于Django的RBAC权限控制模块** 在Web开发中,权限控制是不可或缺的一部分,它确保用户只能访问他们被授权的资源。Role-Based Access Control(RBAC)是一种常见的权限管理模型,通过角色来分配权限,使得系统...

    rbac(基于角色的访问控制)原理讲解

    基于角色的访问控制(RBAC)原理讲解 基于角色的访问控制(RBAC)是一种广泛应用于信息系统中的访问控制机制。其基本思想是在用户和访问权限之间引入角色的概念,将用户和角色联系起来,通过对角色的授权来控制用户...

    【Shiro+RBAC】RBAC(基于角色的访问控制)+Shiro实现权限管理系统.zip

    【Shiro+RBAC】RBAC(基于角色的访问控制)+Shiro实现权限管理系统.zip

    基于RBAC权限管理数据库表设计

    基于RBAC(Role-Based Access Control,基于角色的访问控制)的权限管理是一种广泛采用的策略,它将权限与角色关联,而不是直接分配给单个用户。这种设计模式简化了权限管理,提高了系统的灵活性和可扩展性。下面...

    RBAC权限体系设计UML

    基于角色的访问控制(Role-Based Access Control,简称RBAC)作为一种广泛应用于企业管理信息系统的方法,有效地解决了权限管理中的复杂性问题,提升了系统的安全性与管理效率。本文旨在深入探讨RBAC权限体系的设计...

    RBAC-基于角色的访问控制.doc

    基于角色的访问控制(Role-Based Access Control,简称RBAC)是一种广泛应用于现代系统权限管理的技术。它将权限与角色关联,而不是直接与用户绑定,用户通过扮演特定的角色来获取相应的权限。这种设计思路极大地...

    权限管理、Role Based Access Control(RBAC)基于角色的权限控制-cnesa.zip

    RBAC,即基于角色的权限控制,是一种权限管理系统的设计模型。在RBAC模型中,用户不是直接被赋予权限,而是通过属于特定角色来间接获取权限。角色是预先定义的一组权限集合,用户可以通过被分配一个或多个角色来获得...

    基于RBAC权限管理模型的实现

    在IT行业中,权限管理是系统安全的关键组成部分,而基于RBAC(Role-Based Access Control,基于角色的访问控制)的权限管理模型是一种广泛应用的解决方案。RBAC模型通过将用户权限与角色关联,使得权限分配更加灵活...

    基于角色的访问控制模型(RBAC)

    **基于角色的访问控制(RBAC)**解决了上述问题,通过角色来管理权限。在RBAC模型中,权限不再直接赋予用户,而是赋予角色,用户通过被分配到特定角色来获取相应的权限。这样,授权过程简化,管理负担减轻,并且实现...

    基于springboot的RBAC权限管理演示系统

    这是一个RBAC权限管理系统,即基于角色的用户权限控制,,使用springboot框架开发,UI使用的是layui。。 演示地址:http://116.196.66.248:8090/page/index 欢迎大家下载。。。。另外,建议使用IDEA导入项目。。

    Flask框架实现的RBAC权限管理系统源码

    项目概述:本项目管理系统基于流行的Python Flask框架,实现了一套完整的RBAC(基于角色的访问控制)权限管理功能。项目采用多种编程语言和技术栈,确保了前端的丰富交互和后端的高效稳定。 技术组成: - 主要编程...

    基于RBAC改进模型的角色权限及层次关系分析

    基于角色的访问控制(Role-Based Access Control,简称RBAC)作为一种有效的访问控制机制,近年来受到了广泛关注。1996年,Ravi Sandhu等人提出了一种标准的RBAC模型——RBAC96,它通过定义角色、用户与角色之间的...

Global site tag (gtag.js) - Google Analytics