濮阳杆衣贸易有限公司

主頁 > 知識庫 > RBAC簡介_動力節(jié)點Java學(xué)院整理

RBAC簡介_動力節(jié)點Java學(xué)院整理

熱門標(biāo)簽:小程序智能電話機器人 湖南保險智能外呼系統(tǒng)產(chǎn)品介紹 簡單的智能語音電銷機器人 河北便宜電銷機器人軟件 南昌呼叫中心外呼系統(tǒng)哪家好 ai電話電話機器人 泗洪正規(guī)電話機器人找哪家 怎么申請400熱線電話 怎么去開發(fā)一個電銷機器人

什么是權(quán)限管理

基本上涉及到用戶參與的系統(tǒng)都要進行權(quán)限管理,權(quán)限管理屬于系統(tǒng)安全的范疇,權(quán)限管理實現(xiàn)對用戶訪問系統(tǒng)的控制,按照安全規(guī)則或者安全策略控制用戶可以訪問而且只能訪問自己被授權(quán)的資源。

權(quán)限管理包括用戶身份認(rèn)證和授權(quán)兩部分,簡稱認(rèn)證授權(quán)。對于需要訪問控制的資源用戶首先經(jīng)過身份認(rèn)證,認(rèn)證通過后用戶具有該資源的訪問權(quán)限方可訪問。

用戶身份認(rèn)證

身份認(rèn)證,就是判斷一個用戶是否為合法用戶的處理過程。最常用的簡單身份認(rèn)證方式是系統(tǒng)通過核對用戶輸入的用戶名和口令,看其是否與系統(tǒng)中存儲的該用戶的用戶名和口令一致,來判斷用戶身份是否正確。對于采用指紋等系統(tǒng),則出示指紋;對于硬件Key等刷卡系統(tǒng),則需要刷卡。

 用戶名密碼身份認(rèn)證流程

 

 關(guān)鍵對象

上邊的流程圖中需要理解以下關(guān)鍵對象:

Subject:主體

訪問系統(tǒng)的用戶,主體可以是用戶、程序等,進行認(rèn)證的都稱為主體;

Principal:身份信息

是主體(subject)進行身份認(rèn)證的標(biāo)識,標(biāo)識必須具有唯一性,如用戶名、手機號、郵箱地址等,一個主體可以有多個身份,但是必須有一個主身份(Primary Principal)。

credential:憑證信息

是只有主體自己知道的安全信息,如密碼、證書等。

授權(quán)

授權(quán),即訪問控制,控制誰能訪問哪些資源。主體進行身份認(rèn)證后需要分配權(quán)限方可訪問系統(tǒng)的資源,對于某些資源沒有權(quán)限是無法訪問的。

授權(quán)流程

 下圖中橙色為授權(quán)流程。

 

關(guān)鍵對象

授權(quán)可簡單理解為who對what(which)進行How操作:

n Who,即主體(Subject),主體需要訪問系統(tǒng)中的資源。

n What,即資源(Resource),如系統(tǒng)菜單、頁面、按鈕、類方法、系統(tǒng)商品信息等。資源包括資源類型和資源實例,比如商品信息為資源類型,類型為t01的商品為資源實例,編號為001的商品信息也屬于資源實例。

n How,權(quán)限/許可(Permission),規(guī)定了主體對資源的操作許可,權(quán)限離開資源沒有意義,如用戶查詢權(quán)限、用戶添加權(quán)限、某個類方法的調(diào)用權(quán)限、編號為001用戶的修改權(quán)限等,通過權(quán)限可知主體對哪些資源都有哪些操作許可。

權(quán)限分為粗顆粒和細顆粒,粗顆粒權(quán)限是指對資源類型的權(quán)限,細顆粒權(quán)限是對資源實例的權(quán)限。

主體、資源、權(quán)限關(guān)系如下圖:

 

權(quán)限模型

對上節(jié)中的主體、資源、權(quán)限通過數(shù)據(jù)模型表示。

主體(賬號、密碼)

資源(資源名稱、訪問地址)

權(quán)限(權(quán)限名稱、資源id)

角色(角色名稱)

角色和權(quán)限關(guān)系(角色id、權(quán)限id)

主體和角色關(guān)系(主體id、角色id)

如下圖:

 

通常企業(yè)開發(fā)中將資源和權(quán)限表合并為一張權(quán)限表,如下:

資源(資源名稱、訪問地址)

權(quán)限(權(quán)限名稱、資源id)

合并為:

權(quán)限(權(quán)限名稱、資源名稱、資源訪問地址)

 

上圖常被稱為權(quán)限管理的通用模型,不過企業(yè)在開發(fā)中根據(jù)系統(tǒng)自身的特點還會對上圖進行修改,但是用戶、角色、權(quán)限、用戶角色關(guān)系、角色權(quán)限關(guān)系是需要去理解的。

權(quán)限分配

對主體分配權(quán)限,主體只允許在權(quán)限范圍內(nèi)對資源進行操作,比如:對u01用戶分配商品修改權(quán)限,u01用戶只能對商品進行修改。

權(quán)限分配的數(shù)據(jù)通常需要持久化,根據(jù)上邊的數(shù)據(jù)模型創(chuàng)建表并將用戶的權(quán)限信息存儲在數(shù)據(jù)庫中。

 權(quán)限控制

用戶擁有了權(quán)限即可操作權(quán)限范圍內(nèi)的資源,系統(tǒng)不知道主體是否具有訪問權(quán)限需要對用戶的訪問進行控制。

基于角色的訪問控制

RBAC基于角色的訪問控制(Role-Based Access Control)是以角色為中心進行訪問控制,比如:主體的角色為總經(jīng)理可以查詢企業(yè)運營報表,查詢員工工資信息等,訪問控制流程如下:

 

上圖中的判斷邏輯代碼可以理解為:

if(主體.hasRole("總經(jīng)理角色id")){

查詢工資

}

缺點:以角色進行訪問控制粒度較粗,如果上圖中查詢工資所需要的角色變化為總經(jīng)理和部門經(jīng)理,此時就需要修改判斷邏輯為“判斷主體的角色是否是總經(jīng)理或部門經(jīng)理”,系統(tǒng)可擴展性差。

修改代碼如下:

if(主體.hasRole("總經(jīng)理角色id") || 主體.hasRole("部門經(jīng)理角色id")){

查詢工資

}

基于資源的訪問控制

RBAC基于資源的訪問控制(Resource-Based Access Control)是以資源為中心進行訪問控制,比如:主體必須具有查詢工資權(quán)限才可以查詢員工工資信息等,訪問控制流程如下:

上圖中的判斷邏輯代碼可以理解為:

if(主體.hasPermission("查詢工資權(quán)限標(biāo)識")){

查詢工資

}

優(yōu)點:系統(tǒng)設(shè)計時定義好查詢工資的權(quán)限標(biāo)識,即使查詢工資所需要的角色變化為總經(jīng)理和部門經(jīng)理也只需要將“查詢工資信息權(quán)限”添加到“部門經(jīng)理角色”的權(quán)限列表中,判斷邏輯不用修改,系統(tǒng)可擴展性強。

權(quán)限管理解決方案

粗顆粒度和細顆粒度

 什么是粗顆粒度和細顆粒度

對資源類型的管理稱為粗顆粒度權(quán)限管理,即只控制到菜單、按鈕、方法,粗粒度的例子比如:用戶具有用戶管理的權(quán)限,具有導(dǎo)出訂單明細的權(quán)限。對資源實例的控制稱為細顆粒度權(quán)限管理,即控制到數(shù)據(jù)級別的權(quán)限,比如:用戶只允許修改本部門的員工信息,用戶只允許導(dǎo)出自己創(chuàng)建的訂單明細。

 如何實現(xiàn)粗顆粒度和細顆粒度

對于粗顆粒度的權(quán)限管理可以很容易做系統(tǒng)架構(gòu)級別的功能,即系統(tǒng)功能操作使用統(tǒng)一的粗顆粒度的權(quán)限管理。

對于細顆粒度的權(quán)限管理不建議做成系統(tǒng)架構(gòu)級別的功能,因為對數(shù)據(jù)級別的控制是系統(tǒng)的業(yè)務(wù)需求,隨著業(yè)務(wù)需求的變更業(yè)務(wù)功能變化的可能性很大,建議對數(shù)據(jù)級別的權(quán)限控制在業(yè)務(wù)層個性化開發(fā),比如:用戶只允許修改自己創(chuàng)建的商品信息可以在service接口添加校驗實現(xiàn),service接口需要傳入當(dāng)前操作人的標(biāo)識,與商品信息創(chuàng)建人標(biāo)識對比,不一致則不允許修改商品信息。

您可能感興趣的文章:
  • RBAC權(quán)限模型_動力節(jié)點Java學(xué)院整理

標(biāo)簽:景德鎮(zhèn) 威海 江蘇 那曲 柳州 淮安 瀘州 荊門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《RBAC簡介_動力節(jié)點Java學(xué)院整理》,本文關(guān)鍵詞  RBAC,簡介,動力,節(jié)點,Java,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《RBAC簡介_動力節(jié)點Java學(xué)院整理》相關(guān)的同類信息!
  • 本頁收集關(guān)于RBAC簡介_動力節(jié)點Java學(xué)院整理的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    洱源县| 潍坊市| 旬邑县| 多伦县| 儋州市| 容城县| 和田市| 观塘区| 石棉县| 高唐县| 建阳市| 锡林郭勒盟| 静乐县| 炉霍县| 阿巴嘎旗| 峨山| 库伦旗| 象州县| 定兴县| 鸡东县| 吉首市| 柳州市| 安阳市| 小金县| 合江县| 历史| 扎鲁特旗| 当涂县| 丰城市| 教育| 黄大仙区| 历史| 探索| 保康县| 樟树市| 怀柔区| 望谟县| 鄂托克旗| 五华县| 吉木萨尔县| 宜昌市|