不论什么系统都离不开权限的管理,有一个好的权限管理模块,不仅使我们的系统操作自如,管理方便,也为系统加入亮点。

l        
不同职责的人员,对于系统操作的权限应该是不同的。优秀的业务系统,这是最主要的功能。

l        
能够对“组”进行权限分配。对于一个大企业的业务系统来说,假设要求管理员为其下员工逐一分配系统操作权限的话,是件耗时且不够方便的事情。所以,系统中就提出了对“组”进行操作的概念,将权限一致的人员编入同一组,然后对该组进行权限分配。

l        
权限管理系统应该是可扩展的。它应该能够增加到不论什么带有权限管理功能的系统中。就像是组件一样的能够被不断的重用,而不是每开发一套管理系统,就要针对权限管理部分进行又一次开发。

l        
满足业务系统中的功能权限。传统业务系统中,存在着两种权限管理,其一是功能权限的管理,而第二种则是资源权限的管理,在不同系统之间,功能权限是能够重用的,而资源权限则不能。

针对OA系统的特点,权限说明:

权限

在系统中,权限通过模块+动作来产生,模块就是整个系统中的一个子模块,可能相应一个菜单,动作也就是整个模块中(在B/S系统中也就是一个页面的全部操作,比方“浏览、加入、改动、删除”等)。将模块与之组合能够产生此模块下的全部权限。

权限组

为了更方便的权限的管理,另将一个模块下的全部权限组合一起,组成一个“权限组”,也就是一个模块管理权限,包含全部基本权限操作。比方一个权限组(用户管理),包含用户的浏览、加入、删除、改动、审核等操作权限,一个权限组也是一个权限。

角色

权限的集合,角色与角色之间属于平级关系,能够将基本权限或权限组加入到一个角色中,用于方便权限的分配。

用户组

将某一类型的人、具有同样特征人组合一起的集合体。通过对组授予权限(角色),高速使一类人具有同样的权限,来简化对用户授予权限的繁琐性、耗时性。用户组的划分,能够按职位、项目或其他来实现。用户能够属于某一个组或多个组。

通过给某个人赋予权限,有4种方式(參考飞思办公系统)

A.       
通过职位

a)        
在职位中,职位成员的权限继承当前所在职位的权限,对于下级职位拥有的权限不可继承。

b)       
实例中:如前台这个职位,对于考勤查询有权限,则能够通过对前台这个职位设置考勤查询的浏览权,使他们有使用这个对象的权限,然后再设置个,考勤查询权(当然也能够不设置,默认能进此模块的就能查询),则全部前台人员都拥有考勤查询的权利。

B.       
通过项目

a)        
在项目中,项目成员的权限来自于所在项目的权限,他们相同不能继承下级项目的权限,而对于项目组长,他对项目有全权,对下级项目也一样。

b)       
实例中:在项目中,项目成员能够对项目中上传文档,查看本项目的文档,能够通过对项目设置一个对于本项目的浏览权来实现进口,这样每一个成员能訪问这个项目了,再加上项目文档的上传权和查看文档权就可以。

c)       
对于组长,由于能够赋予组长一个组长权(组长权是个特殊的权限,它包括其它各种权限的一个权限包),全部组长对于本项目有全权,则项目组长能够对于项目文档查看,审批,删除,恢复等,这些权限对于本项目的下级项目依旧有效。

C.      
通过角色

a)        
角色中的成员继承角色的权限,角色与角色没有上下级关系,他们是平行的。通过角色赋予权限,是指没办法按职位或项目的分类来赋予权限的还有一种方式,如:系统管理员,资料备份员…

b)       
实例中:对于本系统中,全体人员应该默认都有的模块,如我的邮件,我的文档,我的日志,我的考勤……,这些模块系统成员都应该有的,我们建立一个角色为系统默认角色,把全部默认訪问的模块的浏览权增加到里面去,则系统成员都能訪问这些模块。

D.      
直接指定

a)        
直接指定是通过对某个人详细指定一项权限,使其有使用这个权限的能力。直接指定是角色指定的一个简化版,为了是在建立像某个项目的组长这样的角色时,省略创建角色这一个步骤,使角色不至于过多。

b)       
实例中:指定某个项目的组长,把组长权指定给某个人。

 

针对职位、项目组:

假设用加入新员工,员工调换职位、项目组,满足了员工会自己主动继承所在职位、项目组的权限,不须要又一次分配权限的功能。

用户管理

用户能够属于某一个或多个用户组,能够通过对用户组授权,来对组中的全部用户进行权限的授予。一个用户能够属于多个项目组,或担任多个职位。

授权管理

将一个基本权限或角色授予用户或用户组,使用户或用户组拥有授予权限的字符串,假设角色、职位、项目中存在同样的基本权限,则取当中的一个;如脱离角色、职位、项目组,仅仅是取消用户或用户组的中此角色、职位、项目组所授予的权限。用户所拥有的权限是全部途径授予权限的集合。管理员用户能够查看每一个用户的终于权限列表。

权限管理

基本操作权限与权限组(基本操作权限的集合)的管理。

物理数据模型图例如以下:

依据以上设计思想,权限管理总共须要下面基本表:

tb_User:用户信息基本表;

tb_Department:部门表;

tb_Company:公司表;

tb_Module:系统模块表;

tb_Action:系统中全部操作的动作表;

tb_Permit:由tb_Module与tb_Action两表结合产生的系统基本权限表;

tb_Permit_Group:权限组表,将一模块的中的全部权限划分一个权限组中,能够通过权限组授予用户权限;

tb_Role:角色表,基本权限的集合。无上级与下级之分;

tb_Position:职位表,有上级与下级之分;

tb_Project:项目组表,

tb_Role_Permit:角色授权表;

tb_Postion_Permit:职位授权表;

tb_Project_Permit:项目授权表;

tb_Project_User:项目成员表,IsLead字段代表此成员为项目组长;

tb_Postion_User:职位成员表;

tb_User_Permit:用户授权表,用户ID与角色、职位、项目及直接授予的权限串表;

权限的产生:

由tb_Module中的ModuleCode与tb_Action中的ActionCode组成

权限代码PermitCode=ModuleCode+ActionCode。

实例:ModuleCode=0101,ActionCode=01,则PermitCode=010101。

权限值则有ModuleValue与ActionCode组合而成,採用下划线来连接。

实例:ModuleValue=Sys_User,ActionValue=AdD,PermitValue= Sys_User_Add

权限组:

包含一组同一模块下的权限的组合,如管理用户包含主要的权限:加入、删除、改动、查看等,将这些组合起来构成一个用户组——“用户管理”权限组。其他类似。仅仅是为了更方便的查看系统权限与权限的分配。

实例:如管理用户的权限代码为010101à查看用户,010102à加入用户,010103à删除用户,010104à改动用户,010105à审核用户等,将这些基本权限组合起来一个集合而构成了“用户管理”权限组。

角色、职位、项目:

也就是按特定的须要划分一种权限的集合。使用角色授权表、职位授权表、项目授权表来实现。授权表中存放的是权限代码PermitCode,而不是权限组的GroupCode代码。

用户授权:

由用户授权表来实现,用户授权表中的RoleCode、PositionCode、ProjectCode各自是角色表中RoleCode组成的串、职位表PositionCode组成的串、ProjectCode组成的串。与角色授权表中的角色代码RoleCode、职位授权表中PositionCode、项目授权表中的ProjectCode不正确应(不是主表与从表之间外键关系)。

从而可以实现了一个用户可以拥有多个角色、多个职位、多个项目的情况。

用户授权表中的PermitCode为直接授权的权限代码串,直接给用户分配权限。

实例:

用户ID为UserId=1的用户权限授权表的记录为:

RoleCode=001,003

PostionCode = 001,002

ProjectCode=001,005

PermitCode = 010101,020102

表明此用户拥有两个角色,代码为001和003,并继承这两个角色的权限;

担任两个职位,代码为001与002,并继承两个职位的权限;

属于两个项目组中的成员,项目代码为001与005,并继承两个项目中的权限。

直接指定给用户的权限为010101与010102这两个权限代码的权限

用户权限字符串:

依据用户授权表的角色代码、职位代码、项目代码得到权限字符串及表中直接分配的权限字符串组合成一个用户的全部权限字符串集合。

OA系统权限管理设计(转载)的更多相关文章

  1. OA系统权限管理设计方案

    (转)OA系统权限管理设计方案 OA系统权限管理设计方案     不同职责的人员,对于系统操作的权限应该是不同的.优秀的业务系统,这是最基本的功能.     可以对“组”进行权限分配.对于一个大企业的 ...

  2. OA系统权限管理设计方案【转】

    l 不同职责的人员,对于系统操作的权限应该是不同的.优秀的业务系统,这是最基本的功能. l 可以对“组”进行权限分配.对于一个大企业的业务系统来说,如果要求管理员为其下员工逐一分配系统操作权限的话,是 ...

  3. OA系统 权限管理的设计流程

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u013630349/article/det ...

  4. OA系统权限管理设计方案学习

    学习之:http://www.cnblogs.com/kivenhou/archive/2009/10/19/1586106.html 此为模型图: 据此写了sql语句: drop table if ...

  5. SQL Server:OA权限管理设计的实现 下

    SQL Server:OA权限管理设计的实现 下   OA系统权限管理设计方案     不同职责的人员,对于系统操作的权限应该是不同的.优秀的业务系统,这是最基本的功能.     可以对“组”进行权限 ...

  6. 基于Spring Security2与 Ext 的权限管理设计与兑现

    基于Spring Security2与 Ext 的权限管理设计与实现 一.Spring Security介绍 Spring Security的前身Acegi,其配置及使用相对来说复杂一些,因为要配置的 ...

  7. Java生鲜电商平台-RBAC系统权限的设计与架构

    Java生鲜电商平台-RBAC系统权限的设计与架构 说明:根据上面的需求描述以及对需求的分析,我们得知通常的一个中小型系统对于权限系统所需实现的功能以及非功能性的需求,在下面我们将根据需求从技术角度上 ...

  8. 26、生鲜电商平台-RBAC系统权限的设计与架构

    说明:根据上面的需求描述以及对需求的分析,我们得知通常的一个中小型系统对于权限系统所需实现的功能以及非功能性的需求,在下面我们将根据需求从技术角度上分析实现的策略以及基于目前两种比较流行的权限设计思想 ...

  9. 解析大型.NET ERP系统 权限模块设计与实现

    权限模块是ERP系统的核心模块之一,完善的权限控制机制给系统增色不少.总结我接触过的权限模块,以享读者. 1 权限的简明定义 ERP权限管理用一句简单的话来说就是:谁 能否 做 那些 事. 文句 含义 ...

随机推荐

  1. zoj 1119 /poj 1523 SPF

    题目描述:考虑图8.9中的两个网络,假定网络中的数据只在有线路直接连接的2个结点之间以点对点的方式传输.一个结点出现故障,比如图(a)所示的网络中结点3出现故障,将会阻止其他某些结点之间的通信.结点1 ...

  2. 【转】setTag()/getTag()

    原文网址:http://www.cnblogs.com/topcoderliu/archive/2011/06/07/2074419.html View中的setTag(Onbect)表示给View添 ...

  3. Solr DIH以Mysql为数据源批量创建索引

    演示使用solr管理后台,以mysql为数据源,批量建索引的方法 测试于:Solr 4.5.1, mmseg4j 1.9.1, Jdk 1.6.0_45, Tomcat 6.0.37 | CentOS ...

  4. Android-onTouchEvent方法的使用

    手机屏幕事件的处理方法onTouchEvent.该方法在View类中的定义,并且所有的View子类全部重写了该方法,应用程序可以通过该方法处理手机屏幕的触摸事件.该方法的签名如下所示. public ...

  5. java web 学习四(http协议)

    一.什么是HTTP协议 HTTP是hypertext transfer protocol(超文本传输协议)的简写,它是TCP/IP协议的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的 ...

  6. 如何解决Rally模板提示angular js加载错误

    [前言] Rally是一个开源测试工具,用于测试openstack各个组件的性能 在使用Rally测试完毕后,一般会生成测试报告,这点很重要.但是原生态的Rally报告模板angular js框架是从 ...

  7. Java Spring boot 系列目录

    Spring boot 介绍 Spring boot 介绍 Spring boot 介绍 Spring boot 介绍 Spring boot 介绍 Spring boot 介绍 Spring boo ...

  8. 判断线段和直线相交 POJ 3304

    // 判断线段和直线相交 POJ 3304 // 思路: // 如果存在一条直线和所有线段相交,那么平移该直线一定可以经过线段上任意两个点,并且和所有线段相交. #include <cstdio ...

  9. Java出现No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing

    Java出现No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing   ...

  10. Java-note-字符串连接

    String a="100"; int b=2; String c=a+b; then the answer is c=1002; + make the two sides bec ...