IT精英俱樂部

          方便自己查閱,僅此而已!

          統(tǒng)計

          留言簿(4)

          閱讀排行榜

          評論排行榜

          RBAC用戶角色權(quán)限設(shè)計方案

          http://www.iteye.com/topic/930648

          RBAC(Role-Based Access Control,基于角色的訪問控制),就是用戶通過角色與權(quán)限進行關(guān)聯(lián)。簡單地說,一個用戶擁有若干角色,每一個角色擁有若干權(quán)限。這樣,就構(gòu)造成“用戶-角色-權(quán)限”的授權(quán)模型。在這種模型中,用戶與角色之間,角色與權(quán)限之間,一般者是多對多的關(guān)系。(如下圖)



          角色是什么?可以理解為一定數(shù)量的權(quán)限的集合,權(quán)限的載體。例如:一個論壇系統(tǒng),“超級管理員”、“版主”都是角色。版主可管理版內(nèi)的帖子、可管理版內(nèi)的用戶等,這些是權(quán)限。要給某個用戶授予這些權(quán)限,不需要直接將權(quán)限授予用戶,可將“版主”這個角色賦予該用戶。 

           

          當(dāng)用戶的數(shù)量非常大時,要給系統(tǒng)每個用戶逐一授權(quán)(授角色),是件非常煩瑣的事情。這時,就需要給用戶分組,每個用戶組內(nèi)有多個用戶。除了可給用戶授權(quán)外,還可以給用戶組授權(quán)。這樣一來,用戶擁有的所有權(quán)限,就是用戶個人擁有的權(quán)限與該用戶所在用戶組擁有的權(quán)限之和。(下圖為用戶組、用戶與角色三者的關(guān)聯(lián)關(guān)系)

          在應(yīng)用系統(tǒng)中,權(quán)限表現(xiàn)成什么?對功能模塊的操作,對上傳文件的刪改,菜單的訪問,甚至頁面上某個按鈕、某個圖片的可見性控制,都可屬于權(quán)限的范疇。有些權(quán)限設(shè)計,會把功能操作作為一類,而把文件、菜單、頁面元素等作為另一類,這樣構(gòu)成“用戶-角色-權(quán)限-資源”的授權(quán)模型。而在做數(shù)據(jù)表建模時,可把功能操作和資源統(tǒng)一管理,也就是都直接與權(quán)限表進行關(guān)聯(lián),這樣可能更具便捷性和易擴展性。(見下圖)



          請留意權(quán)限表中有一列“權(quán)限類型”,我們根據(jù)它的取值來區(qū)分是哪一類權(quán)限,如“MENU”表示菜單的訪問權(quán)限、“OPERATION”表示功能模塊的操作權(quán)限、“FILE”表示文件的修改權(quán)限、“ELEMENT”表示頁面元素的可見性控制等。

           

          這樣設(shè)計的好處有二。其一,不需要區(qū)分哪些是權(quán)限操作,哪些是資源,(實際上,有時候也不好區(qū)分,如菜單,把它理解為資源呢還是功能模塊權(quán)限呢?)。其二,方便擴展,當(dāng)系統(tǒng)要對新的東西進行權(quán)限控制時,我只需要建立一個新的關(guān)聯(lián)表“權(quán)限XX關(guān)聯(lián)表”,并確定這類權(quán)限的權(quán)限類型字符串。

           

          這里要注意的是,權(quán)限表與權(quán)限菜單關(guān)聯(lián)表、權(quán)限菜單關(guān)聯(lián)表與菜單表都是一對一的關(guān)系。(文件、頁面權(quán)限點、功能操作等同理)。也就是每添加一個菜單,就得同時往這三個表中各插入一條記錄。這樣,可以不需要權(quán)限菜單關(guān)聯(lián)表,讓權(quán)限表與菜單表直接關(guān)聯(lián),此時,須在權(quán)限表中新增一列用來保存菜單的ID,權(quán)限表通過“權(quán)限類型”和這個ID來區(qū)分是種類型下的哪條記錄。

           

          到這里,RBAC權(quán)限模型的擴展模型的完整設(shè)計圖如下:



          隨著系統(tǒng)的日益龐大,為了方便管理,可引入角色組對角色進行分類管理,跟用戶組不同,角色組不參與授權(quán)。例如:某電網(wǎng)系統(tǒng)的權(quán)限管理模塊中,角色就是掛在區(qū)局下,而區(qū)局在這里可當(dāng)作角色組,它不參于權(quán)限分配。另外,為方便上面各主表自身的管理與查找,可采用樹型結(jié)構(gòu),如菜單樹、功能樹等,當(dāng)然這些可不需要參于權(quán)限分配。

          posted on 2011-07-30 16:36 suplayer 閱讀(1011) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 密山市| 武宣县| 宣恩县| 刚察县| 卢氏县| 龙井市| 南部县| 定日县| 罗城| 安泽县| 清苑县| 三门县| 文登市| 绍兴市| 阆中市| 西畴县| 武冈市| 凤冈县| 南召县| 漯河市| 蚌埠市| 峨边| 彭山县| 乐业县| 黑山县| 贵州省| 文成县| 九龙县| 宿迁市| 广宁县| 石柱| 灵璧县| 宜宾县| 遵化市| 本溪市| 黄山市| 宁德市| 定远县| 兴文县| 辰溪县| 盈江县|