本節目錄 介紹 Domain Layer Application Layer Infrastructure Layer Web Layer SPA & MPA frameworks/libraries 其他 介紹 為了減少複雜性和提高代碼的可重用性,採用分層架構是一種被廣泛接受的技術。 ABP遵循D
本節目錄
- 介紹
- Domain Layer
- Application Layer
- Infrastructure Layer
- Web Layer
- SPA & MPA
- frameworks/libraries
- 其他
介紹
為了減少複雜性和提高代碼的可重用性,採用分層架構是一種被廣泛接受的技術。
ABP遵循Domain Driven Design,在DDD中,會有4個基礎分層.
- Presentation(展現層): 引用 Application Layer ,提供用戶界面.
- Application(應用層): 作為Presentation and Domain Layers的中間人. 協調business objects 執行特殊的應用.
- Domain(領域層): 整個軟體的核心,包括 business objects and rules.
- Infrastructure: 為其他層提供技術支持. 如數據持久化.
可能會添加的層:
- Distributed Service(分散式服務層): 公開應用層,提供遠程調用.如 ASP.NET Web API and WCF實現該層.
這些都是以domain為中心的架構的通用分層,他們可能會在實現上略微不同.
每一層都可以由1個或多個程式集實現.創建多個程式集作為第三方依賴可能更好(比如Nhibernate).
Domain (Core) Layer
該層會實現所有 business rules.
Entities 提供業務領域的數據和操作. 通常會映射到資料庫中的表.
Repositories 是1個對象集合,可以從資料庫中讀寫entities.通常在Domain Layer 定義,在Infrastructure Layer實現.
Domain Events 定義領域事件並觸發和處理事件.Domain services 處理entities and implement business rules 來解決不屬於單個實體的功能.
Unit of Work 是1種管理實體的設計模式, 將受到業務邏輯影響的實體持久化到資料庫中.
該層需儘可能少的引用第三方庫.
Application Layer
應用層包含展現層需要使用的 application services.
應用服務方法接受1個 DTO (Data Transfer Object) 作為輸入參數,使用這個輸入參數執行一些領域操作.可能會返回另外1個DTO.
通常,不會直接接受和返回實體給展現層.
每個服務方法通常會包括,Unit of Work. User input validation 在該層已實現.
ABP很容易實現自定義驗證.並建議使用 AutoMapper 作為實體到DTOS的轉換
Infrastructure Layer
在基礎設施層中,會使用NHibernate or EntityFramework實現Domain Layer 定義的repositories,ABP提供了這2個ORM的基類.
Database Migrations 建議放在該層.
該層一般為其他層提供依賴的第三方庫.
Web & Presentation Layers
SPA & MPA
Web層可以使用ASP.NET MVC and Web API來實現,可實現成Multi-Page Applications or Single-Page Applications.
在Single-Page Application (SPA) 中會一次載入所有資源(或者懶載入資源)給客戶端,然後通過AJAX調用服務端.服務端返回數據給客戶端,客戶端生成HTML.頁面不會刷新.
有很多JS的SPA框架,如 AngularJs, DurandalJs, BackboneJs, and EmberJs. ABP可以任意結合,且提供了AngularJs and DurandalJs的例子.
在Multi-Page (Classic) Application (MPA),客戶端發1個請求到服務端,服務端從資料庫獲取數據,通過Razor views生成HTML,返回到客戶端展示,每個新的頁面都會導致整個刷新.
SPA and MPA涉及完成不同的架構,後臺管理適合使用SPA架構,博客適合MPA架構,因為博客希望被搜索引擎抓取,雖然有些工具可以讓SPAs對搜索引擎可見,一般還是使用MPA
frameworks/libraries
SignalR是伺服器推送通知的優秀工具,它可以提供豐富,及時的用戶體驗.
還有很多Javascript libraries & frameworks,jQuery是最流行的,擁有眾多免費插件.
也有很多HTML & CSS tools/frameworks,Twitter Bootstrap目前非常火.
ABP提供基礎設施,會為application service自動創建Web API,並且很容易通過JS來調用它(see documentation).
ABP還提供了菜單,本地化localization,語言切換,JS展示系統消息和通知的基礎設施.
ABP自動 handles exceptions,並返回給客戶端合適的結果.
其他
ABP提供並使用 Castle Windsor 作為Dependency Injection.
同時,在服務端使用Log4Net for logging.並且無需改變代碼輕鬆實現切換日誌
ABP使用了非常優秀的frameworks/libraries,並且提供完善的基礎設施,同時,提供templates方便開始1個新項目.