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