這篇文章將為大家詳細講解有關(guān).NET邏輯分層架構(gòu)的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供衛(wèi)輝網(wǎng)站建設(shè)、衛(wèi)輝做網(wǎng)站、衛(wèi)輝網(wǎng)站設(shè)計、衛(wèi)輝網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、衛(wèi)輝企業(yè)網(wǎng)站模板建站服務(wù),10年衛(wèi)輝做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。一.基礎(chǔ)知識準備:
1.層的原則:
(1)每一層以接口方式供上層調(diào)用。
(2)上層只能調(diào)用下層。
(3)依賴分為松散交互和嚴格交互兩種。
2.業(yè)務(wù)邏輯分類:
(1)應(yīng)用邏輯。
(2)領(lǐng)域邏輯。
3.采用的層:
(1)表示層(用戶接口層):領(lǐng)域無關(guān)。
(2)服務(wù)層(應(yīng)用層):應(yīng)用邏輯。
(3)業(yè)務(wù)邏輯層(領(lǐng)域?qū)樱侯I(lǐng)域邏輯。
(4)共享層:提供通用代碼。
(5)實現(xiàn)層:提供接口實現(xiàn)。
4.約定:
(1)領(lǐng)域?qū)幽J采用領(lǐng)域模型
(2)數(shù)據(jù)訪問層默認需要引用領(lǐng)域模型
分層架構(gòu)的三個基本層次為:表示層、業(yè)務(wù)邏輯層和數(shù)據(jù)訪問層。如果按照業(yè)務(wù)邏輯的分類將業(yè)務(wù)邏輯層分解為服務(wù)層和領(lǐng)域?qū)樱瑒t三層擴展為四個層次:表示層、服務(wù)層、領(lǐng)域?qū)雍蛿?shù)據(jù)訪問層。數(shù)據(jù)訪問層一般必須了解領(lǐng)域模型,這將在層之間產(chǎn)生雙向依賴,通常我們有如下兩種解決方案:
1.將領(lǐng)域模型放置在共享層:
評價:PetShop采用此種模型,但缺點眾多:業(yè)務(wù)邏輯層名不副實,領(lǐng)域模型實為數(shù)據(jù)模型,保持了層間依賴,引入了更多依賴,明顯的數(shù)據(jù)驅(qū)動思想,沒有以領(lǐng)域為核心。
2.將數(shù)據(jù)訪問接口定義在業(yè)務(wù)邏輯層:
評價:NopCommerce采用此種模型,即使采用分離出了服務(wù)層和采用了資源庫命名方式,但NopCommerce不是DDD分層架構(gòu),只是采用了領(lǐng)域模型和接口分離原則的普通三層架構(gòu)。缺點:除了數(shù)據(jù)房產(chǎn),沒有將其他具體的技術(shù)依賴從業(yè)務(wù)邏輯層中分離。
三.DDD分層:DDD分層明確的將業(yè)務(wù)邏輯層分成了應(yīng)用層(服務(wù)層)和領(lǐng)域?qū)觾刹糠帧M瑫r將數(shù)據(jù)訪問和其他接口的具體技術(shù)實現(xiàn)部分統(tǒng)一到了基礎(chǔ)設(shè)施層。
1.原始的DDD分層:
評價:優(yōu)點是將具體技術(shù)實現(xiàn)從領(lǐng)域分離,基礎(chǔ)設(shè)施層復用價值增加。缺點是沒有使用共享和實現(xiàn)的概念細分基礎(chǔ)設(shè)施層,導致在基礎(chǔ)設(shè)施層中實現(xiàn)倉儲會產(chǎn)生反向依賴,雖然在單項目解決方案中沒有影響(僅命名空間層次的形式上的依賴),但在.NET多項目解決方案中,只能通過接口分離方式將倉儲實現(xiàn)獨立成類似數(shù)據(jù)訪問層的方式。
2.改善的DDD分層:
評價:基礎(chǔ)設(shè)施層同時具有共享層和實現(xiàn)層的特征。優(yōu)點是終于做到了形式上領(lǐng)域為核心且同時解決了在基礎(chǔ)設(shè)施層中實現(xiàn)倉儲不能引用領(lǐng)域模型的尷尬,缺點是同樣沒有區(qū)分共享和實現(xiàn)的概念。
3.最新的DDD分層:
評價:優(yōu)點是這是真正的以領(lǐng)域為核心,再也不用為基礎(chǔ)設(shè)施層無法引用領(lǐng)域?qū)佣俜?wù)層中再次適配了。使用依賴倒置原則徹底各層對具體技術(shù)的依賴倒置。缺點,依賴倒置應(yīng)用過了頭,同樣是在單項目解決方案中沒有問題,但在.NET多項目解決方案中會導致命名空間形式上的雙向依賴。基礎(chǔ)設(shè)施層作為實現(xiàn)層基本上沒有了復用的價值。更好的方式是調(diào)換圖中用戶接口層和基礎(chǔ)設(shè)施層的位置。
可以根據(jù)需要考慮在上圖添加適當?shù)墓蚕韺印?/p>
四.架構(gòu)的趨勢:
(1)以業(yè)務(wù)邏輯為核心,更加重視業(yè)務(wù)邏輯。
(2)將業(yè)務(wù)邏輯層的具體依賴劃分到一個層次統(tǒng)一管理。
(3)更加重視降低解決方案內(nèi)的依賴性而不是解決方案間的代碼復用。
(4)共享層和實現(xiàn)層的分離將會越來越多的體現(xiàn)。例如洋蔥型架構(gòu)。
關(guān)于“.NET邏輯分層架構(gòu)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
分享文章:.NET邏輯分層架構(gòu)的示例分析-創(chuàng)新互聯(lián)
文章源于:http://vcdvsql.cn/article30/deooso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、商城網(wǎng)站、定制開發(fā)、建站公司、虛擬主機、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容