基于角色的访问控制 (RBAC)权限管理
RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联。简单地说,一个用户拥有若干角色,每一个角色拥有若干权限。这样,就构造成“用户-角色-权限”的授权模型。在这种模型中,用户与角色之间,角色与权限之间,一般者是多对多的关系。
在系统访问中,最终判断的是当前用户拥有哪些权限,以使用相关的权限进行业务处理。
在RBAC中,共有用户、部门、权限、角色四个概念,部门是用户的集合,角色是权限的集合;用户可以拥有不同的权限和角色,部门也可以拥有不同的权限和角色;权限拥有上下级关系,并且在系统中可以有业务权限与数据权限两类;部门拥有上下级关系,此设计方式没有对权限进行继承;部门和用户是一对多的关系,一个部门中可以有多个用户,一个用户只允许属于一个部门。
数据表结构如下:
1.用户表
|
表名:t_user |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
user_id |
varchar(32) |
主键 |
必填 |
主键 |
|
login_name |
varchar(255) |
必填 |
登录用户名 |
|
|
login_pass |
varchar(255) |
必填 |
密码 |
|
|
org_id |
varchar(32) |
外键 |
必填 |
所属机构ID |
|
user_name |
varchar(255) |
必填 |
真实姓名 |
|
|
user_phone |
varchar(255) |
电话号码 |
||
|
user_email |
varchar(255) |
|
||
|
create_date |
varchar(10) |
必填 |
创建日期 |
|
|
create_time |
varchar(8) |
必填 |
创建时间 |
|
|
create_user |
varchar(32) |
外键 |
必填 |
创建人 |
2.机构表
|
表名:t_organization |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
org_id |
varchar(32) |
主键 |
必填 |
主键 |
|
org_name |
varchar(255) |
必填 |
机构名称 |
|
|
org_code |
varchar(255) |
机构编码 |
||
|
org_header |
varchar(255) |
机构负责人 |
||
|
parent_id |
varchar(32) |
表内外键 |
必填 |
上级机构ID,根机构的ID为空 |
|
create_date |
varchar(10) |
必填 |
创建日期 |
|
|
create_time |
varchar(8) |
必填 |
创建时间 |
|
|
create_user |
varchar(32) |
外键 |
必填 |
创建人 |
3.权限表
|
表名:t_right |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
right_id |
varchar(32) |
主键 |
必填 |
主键 |
|
right_name |
varchar(255) |
必填 |
权限名称 |
|
|
right_code |
varchar(255) |
权限编码 |
||
|
parent_id |
varchar(32) |
表内外键 |
必填 |
父权限ID, 根权限的ID为空 |
|
create_date |
varchar(10) |
必填 |
创建日期 |
|
|
create_time |
varchar(8) |
必填 |
创建时间 |
|
|
create_user |
varchar(32) |
外键 |
必填 |
创建人 |
4.用户权限关系表
|
表名:t_user_right |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
ur_id |
varchar(32) |
主键 |
必填 |
主键 |
|
user_id |
varchar(32) |
外键 |
必填 |
用户ID |
|
right_id |
varchar(32) |
外键 |
必填 |
权限ID |
5.机构权限关系表
|
表名:t_org_rigth |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
or_id |
varchar(32) |
主键 |
必填 |
主键 |
|
org_id |
varchar(32) |
外键 |
必填 |
机构ID |
|
right_id |
varchar(32) |
外键 |
必填 |
权限ID |
6.角色表
|
表名:t_role |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
role_id |
varchar(32) |
主键 |
必填 |
主键 |
|
role_name |
varchar(255) |
必填 |
角色名称 |
|
|
create_date |
varchar(10) |
必填 |
创建日期 |
|
|
create_time |
varchar(8) |
必填 |
创建时间 |
|
|
create_user |
varchar(32) |
外键 |
必填 |
创建人 |
7.用户角色关系表
|
表名:t_user_role |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
ur_id |
varchar(32) |
主键 |
必填 |
主键 |
|
user_id |
varchar(32) |
外键 |
必填 |
用户ID |
|
role_id |
varchar(32) |
外键 |
必填 |
角色ID |
8.机构角色关系表
|
表名:t_org_role |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
or_id |
varchar(32) |
主键 |
必填 |
主键 |
|
org_id |
varchar(32) |
外键 |
必填 |
机构ID |
|
role_id |
varchar(32) |
外键 |
必填 |
角色ID |
9.角色权限关系表
|
表名:t_role_right |
||||
|
字段名称 |
字段类型 |
主外键 |
是否必填 |
备注 |
|
rr_id |
varchar(32) |
主键 |
必填 |
主键 |
|
role_id |
varchar(32) |
外键 |
必填 |
角色ID |
|
right_id |
varchar(32) |
外键 |
必填 |
权限ID |
基于角色的访问控制 (RBAC)权限管理的更多相关文章
- [PHP]基于角色的访问控制RBAC
---------------------------------------------------------------------------------------------------- ...
- 移动服务和 Azure Active Directory 中基于角色的访问控制
编辑人员注释:本文章由 Matthew Henderson撰写 去年 11月,我们发布了 Azure Active Directory (AAD) 预览版作为移动服务身份提供程序.此举旨在为企业开 ...
- Azure 门户中基于角色的访问控制入门
面向安全的公司应侧重于向员工提供他们所需的确切权限. 权限过多,可能会向攻击者公开帐户. 权限太少意味着员工无法有效地完成其工作. Azure 基于角色的访问控制 (RBAC) 可通过为 Azure ...
- ThinkPHP中RBAC权限管理的简单应用
RBAC英文全称(Role-Based Access Controller)即基于角色的权限访问控制,简单来讲,一个用户可以拥有若干角色,每一个角色拥有若干权限.这样,就构造成“用户-角色-权限”的授 ...
- PHP RBAC权限管理 基于角色的访问控制演示
RBAC rbac:Role Based Access Controll,基于角色的访问控制. 今天理一理RBAC,话不多说,直接切入主题 功能需求: 权限管理(无限极) 角色管理(可以分配权限) 管 ...
- RBAC(基于角色的访问控制)用户权限管理数据库设计
RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地说,一个用户拥有若干角色,每一个角色拥有若干权限.这样,就构造成“用户-角色- ...
- YIi 权限管理和基于角色的访问控制
验证和授权(Authentication and Authorization) 定义身份类 (Defining Identity Class) 登录和注销(Login and Logout) 访问控制 ...
- RBAC基于角色的访问控制
RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地说,一个用户拥有若干角色,每一个角色拥有若干权限.这样,就构造成"用 ...
- RBAC(Role-Based Access Control,基于角色的访问控制)
RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地说,一个用户拥有若干角色,每一个角色拥有若干权限.这样,就构造成“用户-角色- ...
随机推荐
- 关于mpi的理论知识以及编写程序来实现数据积分中的梯形积分法。
几乎所有人的第一个程序是从“hello,world”程序开始学习的 #include "mpi.h" #include <stdio.h> int main(int a ...
- python3+2 不换行打印,多用于进度条 process bar
python3 不换行打印,多用于进度条 process bar process = 0 # process bar for i in user: process += 1 print("\ ...
- 学习excel的使用技巧统计文本出现的次数
其实是使用一个函数来完成的 =ifcount(C1:C214,''test123") 统计c1到c214中出现的test123的次数
- 使用 nodeJs 开发微信公众号(设置自动回复消息)
微信向第三方服务器发送请求时会降 signature .timestamp. nonce . openid(用户标识),发送内容会以 xml 的形式附加在请求中 回复消息前提我们得拿到用户id , 用 ...
- [Linux]CentOS与终端破墙
来源:https://www.zybuluo.com/ncepuwanghui/note/954160 参考:https://blog.huihut.com/2017/08/25/LinuxInsta ...
- Java开发体系
蓦然回首自己做开发已经十年了,这十年中我获得了很多,技术能力.培训.出国.大公司的经历,还有很多很好的朋友.但再仔细一想,这十年中我至少浪费了五年时间,这五年可以足够让自己成长为一个优秀的程序员,可惜 ...
- Java mysql
- pod 更新慢解决方案
pod install --verbose --no-repo-update pod update --verbose --no-repo-update
- C++重写new和delete,比想像中困难
关于C++内存管理这话题,永远都不过时.在我刚出道的时候,就已经在考虑怎么检测内存泄漏(https://www.cnblogs.com/coding-my-life/p/3985164.html).想 ...
- 二叉搜索树的第K大节点
题目描述 给定一颗二叉搜索树,请找出其中的第k大的结点. 分析 对二叉搜索树进行逆向中序遍历(先右再左),则遍历序列是降序排序的,因此中序遍历一颗二叉搜索树,可以很容易的得到它的第k大的节点.使用一个 ...