.NET邏輯分層架構總結
一.基礎知識準備:
1.層的原則:
(1)每一層以接口方式供上層調用。
?。?)上層只能調用下層。
?。?)依賴分為松散交互和嚴格交互兩種。
2.業(yè)務邏輯分類:
(1)應用邏輯。
(2)領域邏輯。
3.采用的層:
?。?)表示層(用戶接口層):領域無關。
?。?)服務層(應用層):應用邏輯。
?。?)業(yè)務邏輯層(領域層):領域邏輯。
?。?)共享層:提供通用代碼。
?。?)實現(xiàn)層:提供接口實現(xiàn)。
4.約定:
?。?)領域層默認采用領域模型
?。?)數據訪問層默認需要引用領域模型
二.分層架構
分層架構的三個基本層次為:表示層、業(yè)務邏輯層和數據訪問層。如果按照業(yè)務邏輯的分類將業(yè)務邏輯層分解為服務層和領域層,則三層擴展為四個層次:表示層、服務層、領域層和數據訪問層。數據訪問層一般必須了解領域模型,這將在層之間產生雙向依賴,通常我們有如下兩種解決方案:
1.將領域模型放置在共享層:
評價:PetShop采用此種模型,但缺點眾多:業(yè)務邏輯層名不副實,領域模型實為數據模型,保持了層間依賴,引入了更多依賴,明顯的數據驅動思想,沒有以領域為核心。
2.將數據訪問接口定義在業(yè)務邏輯層:
評價:NopCommerce采用此種模型,即使采用分離出了服務層和采用了資源庫命名方式,但NopCommerce不是DDD分層架構,只是采用了領域模型和接口分離原則的普通三層架構。缺點:除了數據房產,沒有將其他具體的技術依賴從業(yè)務邏輯層中分離。
三.DDD分層:
DDD分層明確的將業(yè)務邏輯層分成了應用層(服務層)和領域層兩部分。同時將數據訪問和其他接口的具體技術實現(xiàn)部分統(tǒng)一到了基礎設施層。
1.原始的DDD分層:
評價:優(yōu)點是將具體技術實現(xiàn)從領域分離,基礎設施層復用價值增加。缺點是沒有使用共享和實現(xiàn)的概念細分基礎設施層,導致在基礎設施層中實現(xiàn)倉儲會產生反向依賴,雖然在單項目解決方案中沒有影響(僅命名空間層次的形式上的依賴),但在.NET多項目解決方案中,只能通過接口分離方式將倉儲實現(xiàn)獨立成類似數據訪問層的方式。
2.改善的DDD分層:
評價:基礎設施層同時具有共享層和實現(xiàn)層的特征。優(yōu)點是終于做到了形式上領域為核心且同時解決了在基礎設施層中實現(xiàn)倉儲不能引用領域模型的尷尬,缺點是同樣沒有區(qū)分共享和實現(xiàn)的概念。
3.最新的DDD分層:
評價:優(yōu)點是這是真正的以領域為核心,再也不用為基礎設施層無法引用領域層而再服務層中再次適配了。使用依賴倒置原則徹底各層對具體技術的依賴倒置。缺點,依賴倒置應用過了頭,同樣是在單項目解決方案中沒有問題,但在.NET多項目解決方案中會導致命名空間形式上的雙向依賴。基礎設施層作為實現(xiàn)層基本上沒有了復用的價值。更好的方式是調換圖中用戶接口層和基礎設施層的位置。
可以根據需要考慮在上圖添加適當的共享層。
四.架構的趨勢:
(1)以業(yè)務邏輯為核心,更加重視業(yè)務邏輯。
?。?)將業(yè)務邏輯層的具體依賴劃分到一個層次統(tǒng)一管理。
?。?)更加重視降低解決方案內的依賴性而不是解決方案間的代碼復用。
?。?)共享層和實現(xiàn)層的分離將會越來越多的體現(xiàn)。例如洋蔥型架構。
以上所述就是本文的全部內容了,希望大家能夠喜歡。
相關文章
關于HttpHandler與HttpModule的理解和應用方法
本篇文章小編將為大家介紹,關于HttpHandler與HttpModule的理解和應用方法,有需要的朋友可以參考一下2013-04-04Entity?Framework使用Code?First的實體繼承模式
本文詳細講解了Entity?Framework使用Code?First的實體繼承模式,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03最鋒利的Visual Studio Web開發(fā)工具擴展:Web Essentials使用詳解
Web Essentials是目前為止見過的最好用的VS擴展工具了,具體功能請待我一一道來。2016-06-06如何在ASP.NET Core中給上傳圖片功能添加水印實例代碼
這篇文章主要給大家介紹了關于如何在ASP.NET Core中給上傳圖片功能添加水印的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-02-02ASP.NET GridView中加入RadioButton不能單選的解決方案
這篇文章主要介紹了ASP.NET GridView中加入RadioButton不能單選的解決方案,希望大家閱讀完本文有所收獲。2015-09-09詳解ASP.NET Core和ASP.NET Framework共享身份驗證
本篇文章主要介紹了詳解ASP.NET Core和ASP.NET Framework共享身份驗證 ,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12