【saas-export项目】-RBAC权限模型

该博客介绍了RBAC(Role-Based Access Control)权限模型的实现方式,通过用户表、角色表、权限表和两个中间表来管理用户权限。在MySQL中,使用五张表来构建角色、用户、权限的关系,并展示了如何通过SQL查询获取特定用户(如老王)的权限。博客还提到了权限设计的隐式和显示内连接查询方法。
摘要由CSDN通过智能技术生成

RBAC权限模型引入

(1)如何设计用户权限
普通的用户权限设计
三个表搞定(用户表,权限表,用户权限表)
在这里插入图片描述
(1)五表之间的关系
角色与权限: 多对多。(产生一张角色权限中间表)
用户与角色:多对多。(产生一张用户角色中间表)
Mysql表结构
**加粗样式**
在这里插入图片描述
角色的本质就是一个集合,里面存放在着权限的名称。
给用户指定角色,其实就是将权限打包给用户。

SAAX-Export权限设计

(1)老王有哪些权限?

# 5张表
# 用户表
select * from pe_user;
# 角色表
select * from pe_role;
# 角色用户表(中间表) 得知 一个用户属于哪个角色
select * from pe_role_user;
# 权限表(功能表,模块表)
select * from ss_module;
# 角色权限表(中间表) 得知 一个角色有哪些权限
select * from pe_role_module;

select * from pe_user u,pe_role_user ru,pe_role r ;

## 隐式内连接
select m.name from pe_user u,pe_role_user ru,pe_role r,pe_role_module rm,ss_module m
where u.user_id = ru.user_id 
and ru.role_id = r.role_id 
and r.role_id =  rm.role_id
and rm.module_id = m.module_id
and u.user_name='老王'

## 显示内连接
select m.name from pe_user u inner join pe_role_user ru inner join pe_role r inner join pe_role_module rm inner join ss_module m
on u.user_id = ru.user_id 
and ru.role_id = r.role_id 
and r.role_id =  rm.role_id
and rm.module_id = m.module_id
and u.user_name='老王'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值