当前位置: 首页 > wzjs >正文

网站建设流程发布网站和网页制作智能手机软件开发

网站建设流程发布网站和网页制作,智能手机软件开发,网页显示站点不安全,wordpress windows主题RBAC 权限管理设计 前言权限分类功能权限设计什么是 RBACRBAC 组成RBAC 模型分类基本模型RBAC0角色分层模型RBAC1角色限制模型RBAC2统一模型RBAC3 RBAC0 权限设计用户管理角色管理权限管理关联表 总结 前言 作为一个后台管理系统,权限管理是一个绕不开的话题&#…

RBAC 权限管理设计

    • 前言
    • 权限分类
    • 功能权限设计
      • 什么是 RBAC
      • RBAC 组成
      • RBAC 模型分类
        • 基本模型RBAC0
        • 角色分层模型RBAC1
        • 角色限制模型RBAC2
        • 统一模型RBAC3
      • RBAC0 权限设计
        • 用户管理
        • 角色管理
        • 权限管理
        • 关联表
    • 总结

前言

作为一个后台管理系统,权限管理是一个绕不开的话题,一个成熟的后端系统离不开一个比较完善的权限管理系统,所以本小结我们根据 RBAC 思想来设计一下我们这个系统的权限管理。

权限分类

一般来说,我们常说的权限分为两种,一种是功能权限,一种则是数据权限。

  • 功能权限指的是用户登录系统后能看到什么模块,能看到哪些页面。
  • 数据权限指的是用户在某个模块里面能够看到哪些数据。

在这里插入图片描述

本系统目前只进行功能权限的设计,数据权限默认进行管控,先最小化功能实现,后面有需求在迭代吧。

功能权限设计

目前业界有很多关于权限系统的技术模型,常见的有ACL、ABAC、DAC、RBAC等等,不同体量的权限系统,我们可以参考不同的权限模型进行梳理和设计,本系统就采用一个经典的 RBAC 权限系统模型,我接触的系统基本上都是使用的 RBAC 模型,能满足绝大部分的需求。

什么是 RBAC

RBAC 模型(Role-Based Access Control:基于角色的访问控制)模型是比较早期提出的权限实现模型,在多用户计算机时期该思想即被提出,其中以美国George Mason大学信息安全技术实验室(LIST)提出的RBAC96模型最具有代表,并得到了普遍的公认。

RBAC 认为权限授权的过程可以抽象地概括为:Who 是否可以对What进行How的访问操作,并对这个逻辑表达式进行判断是否为True的求解过程,也即是将权限问题转换为Who、What、How的问题,Who、What、How构成了访问权限三元组,具体的理论可以参考RBAC96。

RBAC的权限授权其实就是Who、What、How的问题。

  • Who:权限的拥用者
  • What:权限针对的资源
  • How:具体的权限

RBAC 组成

RBAC模型的三要素为:用户、角色、权限。

  • 用户:是发起操作的主体,例如:后台管理系统的用户、OA系统的内部员工、面向C端的用户。
  • 角色:用于连接了用户和权限的桥梁,每个角色可以关联多个权限,同时一个用户也可以关联多个角色,那么这个用户就有了多个角色的多个权限。
  • 权限:用户可以访问的资源,包括:页面权限、操作权限、数据权限。

RBAC 模型分类

本系统使用 RBAC0 作为权限设计的方案,够用以及容易学习。

在RBAC中,根据权限设计的复杂程度,可分为RBAC0、RBAC1、RBAC2、RBAC3,我们就重点了解一下我们需要使用到的 RBAC0 模型就行,另外几种有兴趣可以百度一下。

基本模型RBAC0

RBAC0是基础,很多产品只需基于RBAC0就可以搭建权限模型了。在这个模型中,我们把权限赋予角色,再把角色赋予用户。用户和角色,角色和权限都是多对多的关系。用户拥有的权限等于他所有的角色持有权限之和。

在这里插入图片描述

角色分层模型RBAC1

RBAC1建立在RBAC0基础之上,在角色中引入了继承的概念。简单理解就是,给角色可以分成几个等级,每个等级权限不同,从而实现更细粒度的权限管理。

角色限制模型RBAC2

RBAC2同样建立在RBAC0基础之上,仅是对用户、角色和权限三者之间增加了一些限制。这些限制可以分成两类,即静态职责分离SSD(Static Separation of Duty)和动态职责分离DSD(Dynamic Separation of Duty)。

统一模型RBAC3

RBAC3是RBAC1和RBAC2的合集,所以RBAC3既有角色分层,也包括可以增加各种限制。

RBAC0 权限设计

通过上述分析,我们可以发现,设计功能权限离不开最基本的三要素:用户管理、角色管理以及权限管理;根据业务的不同,可能还会涉及更复杂的三要素:部门管理、职位管理、菜单管理等,当然我们使用 RBAC0 只涉及到用简单的3要素。

在这里插入图片描述

用户管理

为了便于大家理解,我们先参考一个优秀的开源框架 EL-ADMIN,给大家截点图理解理解。

在这里插入图片描述

可以很清楚的看到页面上的功能,我们的页面完成之后应该都是差不多的,并且还有一个部门管理,我们也可以有部门管理,但是不加入权限继承。

用户表设计:

字段类型含义
idbigint主键ID
usernamevarchar用户名
mobilechar手机号
avatarvarchar头像
emailvarchar邮箱
passwordvarchar密码
statusint状态 1正常 2锁定
is_deletedatetime是否删除
last_login_timedatetime最后登录时间
create_timedatetime创建时间
create_uservarchar创建用户
update_timedatetime更新时间
update_uservarchar更新用户
角色管理

在这里插入图片描述

上面说了我们的系统暂时是没有数据权限的实现的。

角色表设计:

字段类型含义
idbigint主键ID
namevarchar角色名称
remarkvarchar备注
statusint状态 1正常 2锁定
is_deletedatetime是否删除
create_timedatetime创建时间
create_uservarchar创建用户
update_timedatetime更新时间
update_uservarchar更新用户
权限管理

在这里插入图片描述

权限表设计:

字段类型含义
idbigint主键ID
pidbigint父菜单ID,一级菜单为0
namevarchar菜单名称
urlvarchar菜单URL
permsvarchar授权(多个用逗号分隔,如:user:list,user:create)
typeint类型 0:目录 1:菜单 2:按钮
iconvarchar菜单图标
orderint排序
statusint状态
is_deletedatetime是否删除
create_timedatetime创建时间
create_uservarchar创建用户
update_timedatetime更新时间
update_uservarchar更新用户
关联表

还有两张关联表需要设计,这两张表非常的简单,只有两个字段,分别是两个关联表的id,并且这两个字段都需要设置外键。

用户角色关联表

字段类型含义
user_idbigint用户ID(需要设置外键)
role_idbigint角色ID(需要设置外键)

角色权限关联表

字段类型含义
role_idbigint角色ID(需要设置外键)
menu_idbigint权限ID(需要设置外键)

ok,关于表的设计到这里就结束了,先简单的定了一个基础版本,后续根据开发需求慢慢的在维护修改吧。

总结

关于权限设计这一块,我们采用了 RBAC0 模型来实现,基本上中小型企业都是够用的了。而且简单易上手,学习难度不大,非常适合我们学习,下一小节我们使用 Spring Security 来编写具体的代码实现登录和授权功能。

http://www.dtcms.com/wzjs/563444.html

相关文章:

  • 长沙网站建设长沙潍坊网站制作怎么做
  • 做网站是找什么人123上网之家网址
  • 长春火车站是哪个站计算机技术员网站建设怎么
  • 泉州网站建设泉州公司网络规划与设计
  • 强化网站建设和管理关键词优化除了做网站还有什么方法
  • 公司设计网站需要多少钱策划书
  • 安徽工程建设信息网站6会展设计课程
  • 南阳网站建设 xihewh石家庄网页设计机构
  • 加强网站硬件建设宣传网页设计
  • 个人网站开论坛河北建设工程招标投标协会网站
  • 青岛网站制作方法帝国视频网站模板
  • 做的网站图片显示一半被墙网站怎么做301跳转
  • 珠海建设企业网站公司找人做网站
  • 国外有什么网站做游戏吗无锡市规划建设局网站
  • 南宁新技术产业建设开发总公司网站自己创建小程序
  • 朝阳做网站娄底地seo
  • 如何做本地门户网站北京低价做网站
  • 网站空间800m成华区建设局质检站网站
  • 网站风格包括什么意思科技布沙发好还是布艺沙发好
  • 怎样制作表白网站wordpress 首页轮播
  • 站长是什么级别沈阳企业网站建设
  • 需要网站建设想要自己做一个网站怎么做
  • 网站做淘宝客贵阳网站备案在哪里
  • 网站查询信息网站建设网站栏目结构图
  • 傻瓜式建个人网站春节期间西安有什么好玩的
  • 域名买了之后如何建设网站深圳十大教育培训机构排名
  • 网站后台管理需求免费建立平台网站
  • 如何看网站是否有做网站地图图书馆网站建设的项目报告
  • 贵港做网站建设价格费用国家食品查询网入口
  • 网站右键禁止企业管理系统的构成