`
KC008
  • 浏览: 27909 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

通用数据权限管理系统设计(转载)

阅读更多

通用数据权限管理系统设计
 
作者:逸云  来源:网络
 

前言:

 本文提供一种集成功能权限和数据权限的解决方法,以满足多层次组织中权限管理方面的集中控制。本方法是RBAC(基于角色的访问控制方法)的进一步扩展和延伸,即在功能权限的基础上增加数据权限的管理,实现数据权限和功能权限的集中处理。

 解释:

 功能权限:能做什么的问题,如增加销售订单;
 数据权限:能在哪里干什么的问题,如察看北京分公司海淀销售部张三的销售订单;

 术语:

 资源:系统中的资源,主要是各种业务对象,如销售单、付款单等;
 操作类型:对资源可能的访问方法,如增加、删除、修改等;
 功能:对资源的操作,是资源与操作类型的二元组,如增加销售单、修改销售单等;
 数据类型:业务系统中常用的数据权限类型,如公司、部门、项目、个人等;
 数据对象:具体的业务对象,如甲公司、乙部门等等,包括所有涉及到数据权限的对象值;
 权限:角色可使用的功能,分角色的功能权限和角色的数据权限;
 角色:特定权限的集合;
 用户:参与系统活动的主体,如人,系统等。

 通用数据权限管理系统设计(二)

 方法说明:

 在实际应用中,数据权限的控制点一般相对固定,如针对公司、部门、个人、客户、供应商等,也就是说数据权限一般针对指定数据类型下的一些数据对象。

 本方法中,数据权限的依赖于功能权限,是对功能权限的进一步描述,说明角色在指定的功能点上的数据控制权限。

 本方法中采用“没有明确规定即视为有效”的原则,如果没有定义功能的数据权限,则说明该角色具有该功能的全部的权限。如果定义了功能的某种类型的数据权限,则该用户只具有该类型下指定数据的数据权限。

 这段话比较绕口,下面举个例子实际例子。

 某公司有北京销售部、上海销售部和广州销售部三个销售部,现在需要定义几种角色:

  • 销售总监 -- 能察看所有销售部的销售订单;
  • 北京销售经理 -- 只能察看北京销售部的所有销售订单;
  • 上海销售经理 -- 只能察看上海销售部的所有销售订单;
  • 广州销售经理 -- 只能察看广州销售部的所有销售订单;

上述角色的定义如下:

-------------------------------------------------------------------
 角色名称   功能     数据类型    数据对象 
-------------------------------------------------------------------
 销售总监   察看销售订单 
 北京销售经理 察看销售订单  部门     北京 
 上海销售经理 察看销售订单  部门     上海 
 广州销售经理 察看销售订单  部门     广州 
-------------------------------------------------------------------

 上述定义中,销售总监只定义了功能权限,而没有定义数据权限,所以销售总监能够察看所有的销售订单;而其他几位销售经理分别定义了这一功能的数据权限,所以只能察看指定部门的销售订单。

 在实际应用中,往往会出现部门分组,组长能够察看本组所有人员处理的销售订单的情况,以及某些情况下,某些人只能察看本人的销售订单的情况,这些特殊情况在上述的说明中无法解决,需要在设计和实现中进行处理。

 北京销售代表 -- 只能察看北京销售部的本人的所有销售订单; 

 北京销售代表 察看销售订单 部门 北京 个人 

 通用数据权限管理系统设计(三)--数据库设计

 我们先来看看传统的基于角色的权限管理系统,如下图所示,最简单的基于角色的权限管理由系统功能、系统角色、系统用户、角色功能和用户角色五部分组成。
  
 图一:基于角色的数据库结构

 为实现数据权限控制,在设计上对基于角色的权限管理进行扩充,如下图所示:

 图二:通用数据权限管理系统数据库设计

 对比两张图,我们可以看到,他们之间的主要变化为:

 1、 增加系统资源信息和操作类型信息,系统资源为树形结构、如销售模块、销售订单等;操作类型记录可能的操作,如增加、删除、修改、查看、查询等,系统功能是资源与操作类型的组合,对资源的操作就是系统功能。

 2、 增加数据对象类型和数据对象两张表,数据对象类型记录系统中需要控制的对象类型,如部门、库房、员工、客户、供应商等;数据对象记录各对象类型的对象实例,如北京销售部、上海销售部、张三、李四等等。(独立保存的好处后面会说到)

 3、 增加系统资源与数据对象类型的关联表(多对多),本表为配置表,说明某种资源可能需要的控制点,如销售订单与部门类型的关联可能涉及到分部门分配权限;销售订单与客户的关联可能涉及到按客户分配权限等等。

 4、 增加数据对象与角色权限的关联,这张表是真正最终实现数据权限管理的所在地。

 通过这种设计,能够最小化地减少对原有权限系统的更改,并且可以很灵活地增加数据的控制点。在产品化软件的设计中使用,能够灵活满足客户的需要。

 下一篇文章将讨论这种结构如何满足第二部分功能需求的问题,如果时间允许,将对程序的设计做进一步阐述。

 本设计方法已应用于自行开发的通用供应链管理系统中,欢迎指正。

分享到:
评论

相关推荐

    通用权限管理概要设计说明书

    设计一个灵活、通用、方便的权限管理系统。 在这个系统中,我们需要对系统的所有资源进行权限控制,那么系统中的资源包括哪些呢?我们可以把这些资源简单概括为静态资源(功能操作、数据列)和动态资源(数据),也...

    CMS 网站管理系统 源码

    系统支持设置栏目管理员管理员,同时还可以根据需求分配不同的权限给他们进行管理,帮助用户轻松实现网站多人维护。 6、多重安全机制和权限控制,为网站安全保驾护航 支持后台Cookie加密、验证码IP锁定、IP白名单、...

    asp.net知识库

    Coalesys PanelBar + R.a.d Treeview +Xml 构建的Asp.net 菜单和权限管理模块 突破屏蔽限制,自己的网站使劲弹新IE窗口 对页面SCROLLING的CSS不能生效原因 .Net 中IE使用WinForm控件的使用心得。 动态加载用户控件的...

    网钛文章管理系统 V2.91最新版

    还适用于淘宝客网站,后续网钛工作室将会扩展功能,但不会往功能全面方向发展,只会往功能通用、操作简单的方向发展,让不懂代码但又想建立自己网站的朋友,使用网钛文章管理系统,通过后台简单昱渲茫就能拥有一个...

    网钛文章管理系统

    1、支持自定义文章的路径,使其他系统的数据转移到网钛文章管理系统中,文章路径可保持不变,不影响网站已被搜索引擎收录的数量和排名; 2、支持仿OK3W文章系统的路径 3、支持仿老Y文章系统的路径 4、支持其他大...

    Art2008 CMS 网站管理系统 v3.1.rar

    系统支持设置栏目管理员管理员,同时还可以根据需求分配不同的权限给他们进行管理,帮助用户轻松实现网站多人维护。 6、多重安全机制和权限控制,为网站安全保驾护航 支持后台Cookie加密、验证码IP锁定、IP白名单...

    二十三种设计模式【PDF版】

    关于本站“设计模式” Java 提供了丰富的 API,同时又有强大的数据库系统作底层支持,那么我们的编程似乎变成了类似积木的简单"拼凑"和调用, 甚至有人提倡"蓝领程序员",这些都是对现代编程技术的不了解所至. 在...

    最好的asp CMS系统科讯CMSV7.0全功能SQL商业版,KesionCMS V7.0最新商业全能版-免费下载

    总之:科汛内容网站管理系统适合于各级政府机关、教育机构、组织协会、媒体、企事业单位用来建设地区门户、行业门户、单位内网和外网和收费网站等。从2006年发布至今得到了广大用户的认可及支持,而我们的Kesioncms...

Global site tag (gtag.js) - Google Analytics