架構設計分享之權限系統(tǒng)(看圖說話)
2014-08-31 22:41 圣殿騎士 閱讀(35111) 評論(185) 收藏 舉報前面一篇文章《最近架構隨想》,我提到架構設計的一些構想,其實也是對之前項目經(jīng)驗的一些歸納及總結(jié)。今天我們就以權限系統(tǒng)作為切入點,談一談怎么設計權限系統(tǒng)以及怎么做到系統(tǒng)具有以下特性:
- Organized:如果系統(tǒng)組織比較好,可以起到事半功倍的效果。
- Encapsulated:對功能,結(jié)構,數(shù)據(jù)進行有效的封裝,會使系統(tǒng)維護變得更加容易。
- Reusable:對常用功能以及組件進行有效的封裝,可以使系統(tǒng)變得結(jié)構清晰且方便維護。
- Extensible:在設計系統(tǒng)的時候,如果很好的遵守OO的設計理念(OO的五大原則SOLID),即使系統(tǒng)做得很大,也會像火箭一樣直沖云霄!
- Replaceable:在很多時候我們需要考慮到系統(tǒng),組件或者功能的可替換性,因為需求是會變的。
- Testable:做到系統(tǒng)的可測性,會大大幫助開發(fā)以及維護,對團隊開發(fā)以及分工協(xié)作起著非常重要的作用。
- Loose Coupling:隔離耦合是架構設計必須要考慮的一個因素,如果系統(tǒng)不能做到高內(nèi)聚、低耦合,那么在維護,升級,新功能開發(fā)方面就會是一場噩夢!
- High Performance:高性能是系統(tǒng)設計必須重視的要點,用戶不可能忍受簡單頁面加載超過十秒,也不可能接受頁面操作頻繁卡死的情形,所以在架構設計的時候必須從數(shù)據(jù)庫,邏輯,服務以及UI進行合理的優(yōu)化。
- Scalability:如果能做到前面的幾點,那么我有理由相信你的系統(tǒng)一定具備Scalability。
- Enjoy Your Life:最后一點也是最重要的一點,不要忙碌于重復的碼農(nóng)工作,喝杯咖啡,享受代碼,早點回家,陪老婆、陪小孩,環(huán)球旅游,享受生活!
廢話半天,下面就開始看圖說話環(huán)節(jié):
架構設計圖:
部署及組件圖:
詳細解決方案:
01_Client:存放UI相關的項目,比如Winform, WPF,ASP.NET, Silverlight,ASP.NET MVC或者相關的Web Model及View Model項目。
02_Hosting:存放與Service相關的項目,可以是Direct Service,Remoting Service,Web Service,WCF Service或者Web API Service 。
03_Domain:業(yè)務邏輯相關的所有實體以及操作(根據(jù)OO的思想設計類以及類之間的關系)。
04_Infrastructure:非業(yè)務方面的功能框架 (Data,Common,DataContract,AOP, IOC,Logging,Encryption,Email)。
05_Database:數(shù)據(jù)庫項目(包含所有數(shù)據(jù)庫腳本,方便開發(fā),部署以及維護)。
06_Tests:所有測試項目(數(shù)據(jù)訪問測試,框架測試,業(yè)務邏輯測試,服務測試以及View Model測試)。
07_ReferenceLibs:項目相關的外部引用。
08_Tools:一些簡單的工具,方便開發(fā),測試以及部署。
各層執(zhí)行序列 (調(diào)用Service之前需要調(diào)用Service Adapter,然后根據(jù)項目配置來決定調(diào)用WCF Service,Web API Service 還是直接DLL引用):
權限系統(tǒng)設計 (支持多系統(tǒng),Module多層級,Group多層級,多用戶來源,功能權限,數(shù)據(jù)權限等):
權限系統(tǒng)數(shù)據(jù)庫關系圖(三個中心點:Users, Roles, Paths):
權限系統(tǒng)所有表(包括主要表以及備份表,主要是針對中小型項目,如果大型項目則要采用分庫,分表以及分區(qū)的策略):
數(shù)據(jù)庫項目——腳本注意事項以及如何一鍵執(zhí)行所有數(shù)據(jù)庫腳本(方便管理數(shù)據(jù)庫腳本并且對團隊開發(fā)以及分工協(xié)作幫助很大):
代碼生成器——T4完全生成數(shù)據(jù)庫,業(yè)務實體,業(yè)務層,服務層以及UI代碼 (之前也用Winform和WPF寫過代碼生成器,這是第一次使用T4生成整個項目,感覺非常好用,并且隨時修改隨時使用,而且還可以根據(jù)項目進行定制化)。
這篇文章主要是看圖說話,所以如果你有什么反饋,心得或者建議,不妨留言,我會盡力在今天或者明天進行回復。關于代碼分享或者開源的問題,由于目前是幫公司做的,所以還沒有時間和精力去抽取代碼,不過會根據(jù)反饋,然后在近期內(nèi)分享更多實現(xiàn)細節(jié)!
如果您認為這篇文章還不錯或者有所收獲,不妨點擊一下右下角的(推薦)按鈕,因為你的支持是我繼續(xù)寫作,分享的最大的動力!
作者:圣殿騎士
出處:http://www.rzrgm.cn/KnightsWarrior/
關于作者:專注于微軟平臺項目架構、管理和企業(yè)解決方案。自認在面向?qū)ο螅?面向服務以及微服務領域有一定的造詣,熟悉設計模式、TDD、極限編程、領域驅(qū)動、架構設計、敏捷開發(fā)和項目管理。現(xiàn)主要從事.NET/.NET Core, Go, JavaScript/TypeScript, Azure/AWS等云計算方面的項目開發(fā)、架構、管理和企業(yè)培訓工作。如有問題或建議,請多多賜教!
本文版權歸作者和博客園共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接。如有問題,可以郵件:KnightsWarrior(at)msn(dot)com
微博:圣殿騎士微博 聯(lián)系我,非常感謝。









浙公網(wǎng)安備 33010602011771號