2.基本概念-授权的数据模型

授权的数据模型

  如何进行授权即如何对用户访问资源进行控制,首先需要学习授权相关的数据模型。

  授权可简单理解为Who对What(which)进行How操作,包括如下:

  Who,即主体(Subject),主体一般是指用户,也可以是程序,需要访问系统中的资源。

  What,即资源(Resource),如系统菜单、页面、按钮、代码方法、系统商品信息、系统订单信息等。系统菜单、页面、按钮、代码方法都属于系统功能资源,对于web系统每个功能资源通常对应一个URL;系统商品信息、系统订单信息都属于实体资源(数据资源),实体资源由资源类型和资源实例组成,比如商品信息为资源类型,商品编号 为001的商品为资源实例。

  How,权限/许可(Permission),规定了用户对资源的操作许可,权限离开资源没有意义,如用户查询权限、用户添加权限、某个代码方法的调用权限、编号为001的用户的修改权限等,通过权限可知用户对哪些资源都有哪些操作许可。

  主体、资源、权限关系如下图:
在这里插入图片描述
  主体、资源、权限相关的数据模型如下:

    主体(用户id、账号、密码、…)

    资源(资源id、资源名称、访问地址、…)

    权限(权限id、权限标识、权限名称、资源id、…)

    角色(角色id、角色名称、…)

    角色和权限关系(角色id、权限id、…)

    主体(用户)和角色关系(用户id、角色id、…)

  主体(用户)、资源、权限关系如下图(*表示多个):
在这里插入图片描述
  通常企业开发中将资源和权限表合并为一张权限表,如下:

    资源(资源id、资源名称、访问地址、…)

    权限(权限id、权限标识、权限名称、资源id、…)

  合并为:

    权限(权限id、权限标识、权限名称、资源名称、资源访问地址、…)

  修改后数据模型之间的关系如下图:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
登录用户权限概念模型是基于角色的权限控制(RBAC)模型。在RBAC模型中,用户和权限之间通过角色进行关联,而不是直接关联用户和权限。用户拥有若干个角色,每个角色拥有若干个权限,形成了"用户-角色-权限"的授权模型。这种模型的好处是可以减少频繁的权限设置操作,只需要分配用户相应的角色即可。角色的权限变更比用户的权限变更要少得多,简化了权限管理的复杂性。权限包括页面权限、操作权限和数据权限。页面权限由菜单控制,用户只有拥有相应的菜单权限才能访问页面。操作权限包括页面的功能按钮,如查看、新增、修改和删除等。数据权限指不同用户在同一页面看到的数据是不同的,可以通过将数据和具体的组织结构关联起来来实现。RBAC模型是目前使用最广泛的权限模型之一。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [用户权限设计-基于RBAC模型](https://blog.csdn.net/hudongdong2020/article/details/116837023)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [RBAC权限模型](https://blog.csdn.net/qzw752890913/article/details/124461952)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值