权限相关学习记录

RBAC:基于角色的访问控制方法 

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

解释:

功能权限:能做什么的问题,如新增销售订单;

数据权限:能在哪里干什么的问题,如查看北京分公司海定销售张三的销售订单。

术语:

资源:系统中的资源,主要是各种业务对象,如销售单、付款单等等

操作类型:对资源可能的访问方法,如增加、删除、修改

功能:对资源的操作,是资源与操作类型的二元组,如增加销售单、修改销售单等

数据类型:业务系统中常用的数据权限类型,如公司、部门、项目、个人等

数据对象:具体的业务对象,如甲公司、乙部门等等,包括所有涉及到数据权限的对象值;

权限:角色可以使用的功能,分角色的功能权限和角色的数据权限

角色:特定权限的集合

用户:参与系统活动的主体、如人,系统等

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

方法说明:

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

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

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

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

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

销售总监      -- 能察看所有销售部的销售订单;

北京销售经理 -- 只能察看北京销售部的所有销售订单;

上海销售经理 -- 只能察看上海销售部的所有销售订单;  

广州销售经理 -- 只能察看广州销售部的所有销售订单;  



 角色名称            功能                     数据类型             数据对象  


 销售总监            察看销售订单                                 

 北京销售经理     察看销售订单     部门                     北京  

 上海销售经理     察看销售订单     部门                     上海     

 广州销售经理     察看销售订单     部门                     广州     


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

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



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

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

                                     个人         


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

   

基于角色的权限管理系统,如下图所示,最简单的基于角色的权限管理由系统功能、系统角色、系统用户、角色功能和用户角色五部分组成。

 图一:基于角色的数据库结构


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

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

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

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

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

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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容

  • 文\芦苇 接到好友的电话,听他说着现在的生活与心情,听着他的各种无奈和悲伤,莫名地为他难过,不是因为他当前...
    芦苇花开沐春风阅读 259评论 1 1
  • 16年好与不好都去他的吧……
    OTW2017阅读 239评论 0 0
  • 别人结婚请我们一起去吃饭。 在吃饭的时候,上来了一个菜,我以为是椒盐排骨。就夹了一块,我刚要吃的时候旁边一...
    樊诗豪阅读 154评论 0 0
  • --十年暖心·来不及说爱你---番外 花开月圆终有时,相逢未晚待那年 听完这样的故事!(十年暖心·来不及爱你)...
    南沫有风阅读 481评论 0 1
  • 绕过同时出现的场景 抚摸同时触碰的事物 没有人会记得我们出现过的那条街 陌生的城市 陌生的气息 穿过一条相似的老街...
    资本家白开水阅读 226评论 0 0