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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值