【权限管理】RBAC 和 ABAC的对比

2024-08-27 11:36
文章标签 管理 权限 对比 rbac abac

本文主要是介绍【权限管理】RBAC 和 ABAC的对比,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RBAC 和 ABAC的对比

  • RBAC
    • 三个组成部分
    • 使用
    • 优缺点
  • ABAC
    • 属性
    • 访问策略示例
    • 优缺点
  • RBAC 和 ABAC的对比

RBAC

基于角色的访问控制(role-based access control RBAC)
在这里插入图片描述

三个组成部分

  • 用户
  • 角色
  • 权限

使用

  • 当用户访问系统时,根据用户具备什么角色,允许用户访问哪些菜单、允许访问那些资源。
  • 需要创建拥有不同权限组合的不同角色,比如A角色具有xx权限,B角色拥有yy权限。
  • 需要授予用户权限时,直接授予用户某个角色。
  • 当用户访问系统的某项资源时,如果具备相应的角色,那么系统认为可以访问。

在这里插入图片描述

优缺点

优点:

  • 便于职责的分离
  • 授权方便

缺点:

  • 新增资源时,需要维护所有相关的角色
  • 只能根据静态的参数进行判断

ABAC

基于属性的访问控制(attribute-based access control ABAC)
在这里插入图片描述

当用户访问系统时,根据用户请求时具备的属性,允许用户访问哪些菜单、允许访问那些资源。

属性

属性包括:

  • 用户属性:比如用户的职级、组织、角色。
  • 环境属性:比如访问的时间、访问的IP。
  • 资源属性:比如资源的创建日期、资源的敏感性。
  • 操作属性:增删改查

访问策略示例

当用户请求系统时,根据当前的属性,指定不同的访问策略:

  • 下班时间,不允许访问公司网络,或需要进一步校验身份。
  • 根据职级 + 资源敏感性,确定用户是否有访问权限。
  • 根据职级 + 职位 + 是否在公司内网, 决定用户是否可以下载代码。

在这里插入图片描述

优缺点

优点:

  • 更加灵活,控制更加细粒度,且根据上下文动态执行
  • 新增资源时,只需要维护较少的资源

缺点:

  • 模型构建相对复杂

RBAC 和 ABAC的对比

RBACABAC
基于角色基于属性
根据角色直接具有某些权限根据访问时属性,动态决定是否具有访问权限
新增资源较繁琐新增资源简单
模型简单模型复杂

【仅代表作者个人观点,欢迎大家讨论自己的理解,如有错误,欢迎指正!】


【如果对你有所帮助,希望可以点赞收藏支持一下!】

这篇关于【权限管理】RBAC 和 ABAC的对比的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1111552

相关文章

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Python实现Microsoft Office自动化的几种方式及对比详解

《Python实现MicrosoftOffice自动化的几种方式及对比详解》办公自动化是指利用现代化设备和技术,代替办公人员的部分手动或重复性业务活动,优质而高效地处理办公事务,实现对信息的高效利用... 目录一、基于COM接口的自动化(pywin32)二、独立文件操作库1. Word处理(python-d

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

Spring Security注解方式权限控制过程

《SpringSecurity注解方式权限控制过程》:本文主要介绍SpringSecurity注解方式权限控制过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、摘要二、实现步骤2.1 在配置类中添加权限注解的支持2.2 创建Controller类2.3 Us