許可權系統設計(4)--resource
許可權管理中進行資料訪問控制,其基本模式如下
operation target = selector(resource)
selector = user selector + auth filter
這裡需要對resource的結構,以及選擇運算元的顯式建模。selector必須允許許可權系統追加filter,例如
IDataSource包中所使用的Query物件。
sql語言的表達能力有限, 作為選擇運算元來使用有時需要resource作一些結構上的調整,增加一些冗餘的欄位。例如表達一段時間內的利率,我們需要使用from_date和to_date兩個欄位來進行描述,其中to_date的值與下一條記錄的from_date相同。
value from_date to_date
0.01 2003-01-01 2003-05-01
0.012 2003-05-01 2004-01-01
如果表達一條航線中的多個階段,我們可能會在每條記錄中增加起始站和終點站兩個欄位。
更重要的一個常見需求是樹形結構在關聯式資料庫中的表達。為了能夠直接操縱一個分支下的所有記錄,在層次固定的情況下,我們可能會增加多個分類欄位,例如資料倉儲中的層次維度。在層次數目不確定的情況下,我們將不得不使用層次碼或者類似於url的其他方案,透過layer_code like '01.01.%' 之類的語句實現分支選擇。為了限制選擇的深度,我們可能還需要layer_level欄位。基於層次碼和層次數,我們可以建立多種選擇運算元,例如包含所有直接子節點,包含自身及所有父節點等等。
請參考: http://space.itpub.net/?uid-29867-action-viewspace-itemid-233308
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29867/viewspace-233309/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 許可權系統:許可權應用服務設計
- 許可權系統:許可權應用服務設計Tu
- 許可權系統:6個許可權概念模型設計模型
- 許可權設計
- 關於系統許可權的設計-位操作
- 分散式系統中,許可權設計實踐分散式
- Spring Security + jwt 許可權系統設計,包含SQLSpringJWTSQL
- Linux系統程式設計(七)檔案許可權系統呼叫Linux程式設計
- 許可權系統:一文搞懂功能許可權、資料許可權
- 通用許可權系統之資料庫表設計資料庫
- learun通用許可權系統框架功能實現設計框架
- 手把手擼套框架-許可權系統設計框架
- 管理系統之許可權的設計和實現
- 如何設計應用系統的資料許可權管理
- 基於Spring Security和 JWT的許可權系統設計SpringJWT
- mongodb 的許可權系統MongoDB
- 有贊許可權系統
- android 許可權元件設計Android元件
- JavaWeb許可權設計原理JavaWeb
- 若依管理系統RuoYi-Vue(二):許可權系統設計詳解Vue
- 4、許可權管理
- [仁潤雲技術團隊]許可權系統的設計
- 授權許可權服務設計解析
- 許可權維持專題:作業系統許可權維持作業系統
- 企業許可權管理系統
- Winner許可權管理系統3.0
- 領域驅動設計之實戰許可權系統微服務微服務
- SpringSecurity許可權管理系統實戰—九、資料許可權的配置SpringGse
- Linux系統ACL許可權設定之setfacl和getfaclLinux
- 打造自己的系統許可權控制
- PingCode Wiki 許可權設計之ACLGC
- 選單許可權和按鈕許可權設定
- Confluence6對比系統管理員許可權和Confluence管理員許可權
- 語音交友app開發許可權系統,不容錯過的設計方案APP
- 如何利用 Spring Hibernate 高階特性設計實現一個許可權系統Spring
- win10軟體許可權設定在哪裡 W10系統怎麼設定應用的許可權Win10
- 擴充套件.Django-許可權系統套件Django
- OA管理系統,有哪些許可權管理?
- 基於RBAC的許可權管理系統