一.三層架構圖
二.系統各層次職責
1.UI(User Interface)層的職責是資料的展現和采集,資料采集的結果通常以Entity object送出給BL層處理。與UI平行的Service Interface層用于将業務釋出為服務(如WebServices)。
2.BL(Business Logic)層的職責是按預定的業務邏輯處理UI層送出的請求。
(1)Business class 子層負責基本業務功能的實作。
(2)Business Flow 子層負責将Business class子層提供的多個基本業務功能組織成一個完整的業務流。(Transaction通常在Business Flow 子層開啟。)
3.DataAccess層的職責是提供全面的資料通路功能支援,并向上層屏蔽所有的SQL語句以及資料庫類型差異。
(1)DB Adapter子層負責屏蔽資料庫類型的差異。
(2)ORM子層負責提供對象-關系映射的功能。
(3)Relation子層提供ORM無法完成的基于關系(Relation)的資料通路功能。
(4)BEM(Business Entity Manager)子層采用ORM子層和Relation子層來提供業務需要的基礎資料通路能力。
三.Aspect
Aspect貫穿于系統各層,是系統的橫切關注點。通常采用AOP技術來對橫切關注點進行模組化和實作。
1.Securtiy Aspect:用于對整個系統的Security提供支援。
2.ErrorHandling Aspect:整個系統采用一緻的錯誤/異常處理方式。
3.Log Aspect:用于系統異常、日志記錄、業務操作記錄等。
四.規則
1.系統各層次及層内部子層次之間都不得跨層調用。
2.Entity object 在各個層之間傳遞資料。
3.需要在UI層綁定到清單的資料采用基于關系的DataSet傳遞,除此之外,應該使用Entity object傳遞資料。
4.對于每一個資料庫表(Table)都有一個Entity class與之對應,針對每一個Entity class都會有一個BEM Class與之對應。
5.在數量上,BEM Class比Entity class要多,這是因為有些跨資料庫或跨表的操作(如複雜的聯合查詢)也需要由相應的BEM Class來提供支援。
6.對于相對簡單的系統,可以考慮将Business class 子層和Business Flow 子層合并為一個。
7.UI層和BL層禁止出現任何SQL語句。
五.錯誤與異常
異常可以分為系統異常(如網絡突然斷開)和業務異常(如使用者的輸入值超出最大範圍),業務異常必須被轉化為業務執行的結果。
1.DataAccess層不得向上層隐藏任何異常(該層抛出的異常幾乎都是系統異常)。
2.要明确區分業務執行的結果和系統異常。比如驗證使用者的合法性,如果對應的使用者ID不存在,不應該抛出異常,而是傳回(或通過out參數)一個表示驗證結果的枚舉值,這屬于業務執行的結果。但是,如果在從資料庫中提取使用者資訊時,資料庫連接配接突然斷開,則應該抛出系統異常。
3.在有些情況下,BL層應根據業務的需要捕獲某些系統異常,并将其轉化為業務執行的結果。比如,某個業務要求試探指定的資料庫是否可連接配接,這時BL就需要将資料庫連接配接失敗的系統異常轉換為業務執行的結果。
4.UI層除了從調用BL層的API擷取的傳回值來檢視業務的執行結果外,還需要截獲所有的系統異常,并将其解釋為友好的錯誤資訊呈現給使用者。
六.項目目錄結構
1.目錄結構:以EAS系統為例。
2.命名空間命名:每個dll的根命名空間即是該dll的名字,如EAS.BL.dll的根命名空間就是EAS.BL。每個根命名空間下面可以根據需求的分類而增加子命名空間,比如,EAS.BL的子空間EAS.BL.Order與EAS.BL.Permission分别處理不同的業務邏輯。
七.釋出服務與服務回調
以EAS系統為例。
1.如果EAS系統提供了WebService(Remoting)服務,則EAS必須提供EAS.Entrance.dll。EAS.Entrance.dll封裝了與EAS服務交換資訊的通信機制,客戶系統隻要通過EAS.Entrance.dll就可以非常簡便地通路EAS提供的服務。
2.如果EAS需要通過WebService(Remoting)回調客戶系統,則必須提供僅僅定義了接口的EAS.CallBack.dll,客戶系統将引用該dll,實作其中的接口,并将其釋出為服務,供EAS回調。
3.當WebService的參數或傳回值需要是複雜類型,則該複雜類型應該在對應的EAS.Entrance.dll或EAS.CallBack.dll中定義,WebService定義的方法中的複雜類型應該使用Xml字元串代替,而Xml字元串和複雜類型對象之間的轉換應當在EAS.Entrance.dll或EAS.CallBack.dll中實作。