用户和角色:通用权限管理系统数据库表结构设计

转:用户和角色:通用权限管理系统数据库表结构设计

一、前言

权限管理系统的应用者应该有三种不同性质上的使用

  1. 使用权限
  2. 分配权限
  3. 授权权限

本文只从《使用权限》和《分配权限》这两种应用层面分析,暂时不考虑《授权权限》这种。

二、初步分析用户和角色

说到权限管理,首先应该想到,当然要设计一个用户表,一个权限表。这样就决定了一个人有什么样的权限。
做着做着就会发现这样设计太过繁琐,如果公司里面所有员工都有这样的权限呢,每一个人都要配置?那是一件很痛苦的事情。因此再添加一个角色表,把某些人归为一类,然后再把权限分配给角色。角色属下的用户也就拥有了权限。
用户、角色之间的关系是一个用户可以对应多个角色,一个角色可以对应多个用户,多对多关系。
所以需要一个中间表,相信大家都很熟悉,自然不会有疑问。
应用场景:有了用户和角色以后,就需要设计应用场景,比如一个应用程序有几大模块(系统模块、项目管理模块、销售模块),类似这样的模块就是一种应用场景,常见的还有 菜单 、 操作 等等。
假设现在我们设计好了,应用场景包括 模块、菜单、和操作,那么应该有以下六种关系

  • 一个用户可以对应多个模块,一个模块可以对应多个用户。多对多关系。
  • 一个用户可以对应多个菜单,一个菜单可以对应多个用户。多对多关系。
  • 一个用户可以对应多个操作,一个操作可以对应多个用户。多对多关系。
  • 一个角色可以对应多个模块,一个模块可以对应多个角色。多对多关系。
  • 一个角色可以对应多个菜单,一个菜单可以对应多个角色。多对多关系。
  • 一个角色可以对应多个操作,一个操作可以对应多个角色。多对多关系。

于是建立六张表来维护这六种关系。
这样设计看起来没什么问题。是的,如果没有加入新的关系的话,这样是已经可以满足大部分的需求了。可是如果就是如果,新的关系(需求)往往会加入到系统进来。这个时候就需要再建立一个新的表。系统的复杂度也随着增加。
可以看出,这样的设计有几个问题:

  • 数据表设计太复杂
  • 应对系统方案过于固定

三、把问题简单化

不同的应用场合,你可能会想出不同的需求,提了一个新的需求以后,可能会发现原来的设计没方法实现了,于是还要添加一个新的表。这也是上面所提到的问题。
其实不必想得那么复杂,权限可以简单描述为:
某某主体某某领域某某权限

  1. 主体可以是用户,可以是角色,也可以是一个部门

  2. 领域可以是一个模块,可以是一个页面,也可以是页面上的按钮

  3. 权限可以是“可见”,可以是“只读”,也可以是“可用”(如按钮可以点击)

其实就是WhoWhatHow的问题

因此上面所提到的六张表其实可以设计一张表:

下面用一个例子做设计说明:用户、角色在页面上的使用权限
效果图

 

数据库设计


详细设计:

  1. 把菜单的配置放在数据库上,每一个菜单对应一个唯一的编码MenuNo,每一个“叶节点”的菜单项对应一个页面(url)。
  2. 把按钮的配置放在数据库上,并归属于一个菜单项上(其实就是挂在某一个页面上)。应该一个页面可能会有几个按钮组,比如说有两个列表,这两个列表都需要有“增加、修改、删除”。所以需要增加一个按钮分组的字段来区分。
  3. 把菜单权限分配给用户/角色,
    PrivilegeMaster为"User"或"Role",
    PrivilegeMasterValue为UserID或RoleID,
    PrivilegeAccess为“Menu",
    PrivilegeAccessValue为MenuNo,
    PrivilegeOperation为"enabled"
  4. 把按钮权限分配给用户/角色,
    PrivilegeMaster为"User"或"Role",
    PrivilegeMasterValue为UserID或RoleID,
    PrivilegeAccess为“Button",
    PrivilegeAccessValue为BtnID,
    PrivilegeOperation为"enabled"
  5. 如果需要禁止单个用户的权限,PrivilegeOperation 设置为"disabled"。

五、结语

说了这么多,其实我推荐的只是Privilege的表设计。这个表是who、what、how问题原型的设计。不仅扩展性、灵活性都很好,而且将复杂的权限管理系统浓缩成一句话。

而PrivilegeOperation不仅仅只是使用和禁止两种,包括分配权限、授权权限,都可以用这个字段定义。只是这无疑加大了应用程序的设计难度,但是对于表设计可以不做出任何的修改就可以完成,可以看出其灵活性。

 

  • 0
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
通用权限管理框架源码 2013-5-15更新功能: 1、菜单导航管理 2、操作按钮 3、角色管理 4、部门管理 5、用户管理(用户权限) 6、用户组管理(设置成员,用户权限) 7、系统配置(动态配置系统参数) 8、附加属性(自定义属性) 9、系统日志(异常记录) 10、数据库备份/还原 11、资源管理,(动态数据库) 12、个人信息(基本信息,附加信息,用户角色,拥有权限) 13、首页快捷 14、数据回收站(业务功能删除过数据,全部保留在回收站) 15、系统个性化设置(切换菜单导航) 2012-9-10更新内容: 系统UI,给人感觉非常好,体积小巧,速度快 该源码是适用用于应用系统后台模块的管理(可扩展至支持集中化的权限管理平台), 0.支持N级菜单导航,菜单显示方式支持目前支持2种模式分别:菜单(无限级),横向(2级) 1.动态切换皮肤,目前有两狂UI 蓝色,咖啡色 2.单验证,文本框高亮起来 3.可以动态分配权限按钮,分配角色权限,目录结构,栏目的链接都可以修改。权限管理非常灵活, 4.可以隐藏左侧导航栏,打开左侧导航栏,默认是打开,table格都自应大小的 5.动态创建数据表,删除用户,点击数据 可以查询字段信息 6.可以直接执行sql脚本 7.兼容 IE6,7,8,9 /Firefox /Google Chrome 这些浏览器都测试过 8.批量删除,自定义复选框样式,可以全选/反选 9.角色分级,集团和分公司的关系 10.权限 横向就是业务部分,具体负责哪块业务,纵向是级别 11.动态报设置,并且可以导出Excel 12.登陆日记,操作日记,异常日记 13.海量批量删除数据库,调用公共存储过程,参数,明,主键 特点: UI:传统html css,美观 漂亮 大方 实用 js框架:jquery 系统大部分使用AJAX操作。大大提高了用户体验 功能描述: 1.支持N级菜单导航,菜单显示方式支持目前支持2种模式分别: 菜单(无限级),横向(2级) 2.单验证,文本框高亮起来 3.可以动态分配权限按钮,分配角色权限,目录结构,栏目的链接都可以修改。 4.可以隐藏左侧导航栏,打开左侧导航栏,默认是打开,table格都自应大小的 5.动态创建数据表,删除用户,点击数据 可以查询字段信息 6.可以直接执行sql脚本
设计javaweb通用权限管理系统的数据库结构时,需要考虑以下几个方面: 1. 用户设计:应该包含用户ID、用户名、密码等基本信息,用于存储用户的登录信息。 2. 角色设计:应该包含角色ID和角色名称等基本信息,用于存储角色的基本信息。 3. 权限设计:应该包含权限ID和权限名称等基本信息,用于存储系统中各种权限的定义。 4. 用户角色关系设计:应该包含用户ID和角色ID等基本信息,用于建立用户角色之间的关系。 5. 角色权限关系设计:应该包含角色ID和权限ID等基本信息,用于建立角色权限之间的关系。 通过以上设计,可以实现通用权限管理系统的基本需求,包括用户的登录和验证、角色的定义和分配、权限的定义和控制等。 此外,还可以考虑以下的优化措施: 1. 缓存策略:可以使用缓存来提高系统的性能,例如将用户信息、角色信息和权限信息等常用数据存储在内存中,避免频繁访问数据库。 2. 数据库索引:通过在关键字段上创建索引,可以提高数据库查询的效率,加快系统的响应速度。 3. 数据库连接池:使用数据库连接池可以减少系统连接数据库的开销,提高系统的并发性能。 总之,javaweb通用权限管理系统的数据库结构设计需要合理地考虑用户角色权限等基本信息的存储方式,同时还需要考虑系统的性能和安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值