Duwamish深入剖析-結(jié)構(gòu)篇
摘要:
本文深入詳細(xì)的介紹了Duwamish網(wǎng)上電子書店例程的結(jié)構(gòu)框架,并詳細(xì)的分析了該結(jié)構(gòu)的若干特點(diǎn)和設(shè)計(jì)模式。
目錄:
引言
Duwamish介紹
結(jié)構(gòu)分析
設(shè)計(jì)思想
代碼示例
總結(jié)
引言:
能夠作為Visual Studio .Net附帶的例子,Duwamish一定包含了微軟.Net設(shè)計(jì)隊(duì)伍希望向開發(fā)者傳達(dá)的某些信息,而事實(shí)上,Duwamish也的確能夠稱作是一個(gè).Net開發(fā)者學(xué)習(xí)的經(jīng)典示例,無(wú)論是從其設(shè)計(jì)架構(gòu),編程技巧或代碼風(fēng)格,都向我們展示了一個(gè)標(biāo)準(zhǔn)的.Net企業(yè)級(jí)應(yīng)用程序所應(yīng)該具有的特點(diǎn)。所以,通過研究Duwamish示例,高手能夠領(lǐng)悟到.Net應(yīng)用架構(gòu)的設(shè)計(jì)思想,低手能夠?qū)W習(xí)到.Net的編程技巧,實(shí)在是老少皆宜。 :)
不過,本文的目的更多的是針對(duì)中級(jí).Net學(xué)習(xí)者,這類讀者往往已經(jīng)熟悉了C#或者是VB.NET的語(yǔ)法,會(huì)用一些基本的類庫(kù),并已經(jīng)會(huì)做一些比較小的程序。但是當(dāng)他們開始著手開發(fā)一個(gè)真正具有實(shí)用價(jià)值的企業(yè)級(jí)應(yīng)用的時(shí)候,卻有種無(wú)處下手的感覺。如果你正巧屬于這類學(xué)習(xí)者,請(qǐng)跟著我深入到Duwamish的世界中去,相信你一定會(huì)得到收獲。
Duwamish介紹:
Microsoft公司每次推出新技術(shù),總是會(huì)相應(yīng)的推出一些公開源代碼的應(yīng)用范例來(lái)說(shuō)明該項(xiàng)新技術(shù)的特點(diǎn),而開發(fā)者也能通過研究該范例的代碼來(lái)達(dá)到迅速掌握新技術(shù)并與以實(shí)施的目的。Microsoft通過對(duì)一個(gè)虛擬的在網(wǎng)上銷售圖書的電子商務(wù)公司網(wǎng)上銷售系統(tǒng)應(yīng)用的創(chuàng)建,向用戶展現(xiàn)了典型的網(wǎng)上購(gòu)物實(shí)踐中最為普遍的電子商務(wù)企業(yè)對(duì)客戶 (B2C) 模式,它包括成員資格、帳戶管理、購(gòu)物車、搜索和結(jié)帳過程等基本功能。Duwamish經(jīng)歷了三個(gè)版本4.0,5.0和7.0版,每一個(gè)版本的發(fā)布都印證了技術(shù)進(jìn)步的過程,每一個(gè)版本都代表了當(dāng)時(shí)最先進(jìn)的技術(shù)動(dòng)向。這里將要研究和討論的是Duwamish的最高版本7.0版,經(jīng)歷了COM/COM+技術(shù)以及Microsoft DNA架構(gòu)的Duwamish,在最新的版本中完全采用了.Net技術(shù)及架構(gòu),比以前顯得更加先進(jìn)和成熟。
如果您安裝了Visual Studio .Net的話,您可以在您的VS.Net 的Enterprise Samples目錄下找到并安裝它,例如:C:\Program Files\Microsoft Visual Studio .NET\Enterprise Samples\,或者您還可以到http://astradigital.com/Duwamish7Vb/這個(gè)地址去看看它在Internet的一個(gè)演示實(shí)例。其它有關(guān)Duwamish的詳細(xì)介紹資料請(qǐng)參考Visual Studio .Net附帶的MSDN幫助,地址是:ms-help://MS.VSCC/MS.MSDNVS.2052/dwamish7/html/vtoriDuwamishBooks70.htm,這里不再贅述。
Duwamish結(jié)構(gòu)分析:
Duwamish 7.0 是一個(gè)典型的N層架構(gòu),其結(jié)構(gòu)分為四個(gè)邏輯層:
Web 層
Web 層為客戶端提供對(duì)應(yīng)用程序的訪問。這一層是作為 Duwamish.sln 解決方案文件中的 Web 項(xiàng)目實(shí)現(xiàn)的。Web 層由 ASP.NET Web 窗體和代碼隱藏文件組成。Web 窗體只是用 HTML 提供用戶操作,而代碼隱藏文件實(shí)現(xiàn)各種控件的事件處理。
業(yè)務(wù)外觀層
業(yè)務(wù)外觀層為 Web 層提供處理帳戶、類別瀏覽和購(gòu)書的界面。這一層是作為 Duwamish.sln 解決方案文件中的 BusinessFacade 項(xiàng)目實(shí)現(xiàn)的。業(yè)務(wù)外觀層用作隔離層,它將用戶界面與各種業(yè)務(wù)功能的實(shí)現(xiàn)隔離開來(lái)。除了低級(jí)系統(tǒng)和支持功能之外,對(duì)數(shù)據(jù)庫(kù)服務(wù)器的所有調(diào)用都是通過此程序集進(jìn)行的。
業(yè)務(wù)規(guī)則層
業(yè)務(wù)規(guī)則層是作為 Duwamish.sln 解決方案文件中的 BusinessRules 項(xiàng)目實(shí)現(xiàn)的,它包含各種業(yè)務(wù)規(guī)則和邏輯的實(shí)現(xiàn)。業(yè)務(wù)規(guī)則完成如客戶帳戶和書籍訂單的驗(yàn)證這樣的任務(wù)。
數(shù)據(jù)訪問層
數(shù)據(jù)訪問層為業(yè)務(wù)規(guī)則層提供數(shù)據(jù)服務(wù)。這一層是作為 Duwamish.sln 解決方案文件中的 DataAccess 項(xiàng)目實(shí)現(xiàn)的。
比較令人困惑的是其中的業(yè)務(wù)外觀層和業(yè)務(wù)規(guī)則層,很多人在學(xué)習(xí)N層結(jié)構(gòu)開發(fā)的時(shí)候,聽得最多的是三層結(jié)構(gòu),分別為:表示層,中間層和數(shù)據(jù)層。Duwamish的WEB層和數(shù)據(jù)訪問層比較好理解,也就是傳統(tǒng)意義上的表示層和數(shù)據(jù)層,那么業(yè)務(wù)外觀層和業(yè)務(wù)規(guī)則層和我們熟悉的中間層有什么聯(lián)系呢?
設(shè)計(jì)思想:
在Web應(yīng)用程序中,有部分操作只是簡(jiǎn)單的從數(shù)據(jù)庫(kù)根據(jù)條件提取數(shù)據(jù),不需要經(jīng)過任何處理,而直接將數(shù)據(jù)顯示到網(wǎng)頁(yè)上,比如查詢某類別的圖書列表。而另外一些操作,比如計(jì)算定單中圖書的總價(jià)并根據(jù)顧客的級(jí)別計(jì)算回扣等等,這部分往往有許多不同的功能的類,操作起來(lái)也比較復(fù)雜。我們可以先想象一下,如果我們采用三層結(jié)構(gòu),這些商業(yè)邏輯一般是會(huì)放在中間層,那么對(duì)內(nèi)部的這些大量種類繁多,使用方法也各異的不同的類的調(diào)用任務(wù),就完全落到了表示層。這樣勢(shì)必會(huì)增加表示層的代碼量,將表示層的任務(wù)復(fù)雜化,和表示層只負(fù)責(zé)接受用戶的輸入并返回結(jié)果的任務(wù)不太相稱,并增加了層與層之間的耦合程度。
為了解決這個(gè)問題,我們先來(lái)看看《設(shè)計(jì)模式》一文中對(duì)Facade模式的描述:
意圖:
為子系統(tǒng)中的一組接口提供一個(gè)一致的界面,F(xiàn)acade模式定義了一個(gè)高層接口,這個(gè)接口使得這一子系統(tǒng)更加容易使用。
適用性:
當(dāng)你要為一個(gè)復(fù)雜子系統(tǒng)提供一個(gè)簡(jiǎn)單接口時(shí)。子系統(tǒng)往往因?yàn)椴粩嘌莼兊迷絹?lái)越復(fù)雜。大多數(shù)模式使用時(shí)都會(huì)產(chǎn)生更多更小的類。這使得子系統(tǒng)更具可重用性,也更容易對(duì)子系統(tǒng)進(jìn)行定制,但這也給那些不需要定制子系統(tǒng)的用戶帶來(lái)一些使用上的困難。Facade可以提供一個(gè)簡(jiǎn)單的缺省視圖,這一視圖對(duì)大多數(shù)用戶來(lái)說(shuō)已經(jīng)足夠,而那些需要更多的可定制性的用戶可以越過Facade層。
客戶程序與抽象類的實(shí)現(xiàn)部分之間存在著很大的依賴性。引入Facade將這個(gè)子系統(tǒng)與客戶以及其他的子系統(tǒng)分離,可以提高子系統(tǒng)的獨(dú)立性和可移植性。
當(dāng)你需要構(gòu)建一個(gè)層次結(jié)構(gòu)的子系統(tǒng)時(shí),使用Facade模式定義子系統(tǒng)中每層的入口點(diǎn)。如果子系統(tǒng)之間是相互依賴的,你可以讓它們僅通過Facade進(jìn)行通訊,從而簡(jiǎn)化了它們之間的依賴關(guān)系。
結(jié)構(gòu)圖:
上文提出的這個(gè)矛盾,正好和設(shè)計(jì)模式中Facade模式中所描述的需要解決的問題非常吻合,在《設(shè)計(jì)模式》中提出的解決的辦法就是引入一個(gè)Facade對(duì)象,讓這個(gè)Façade來(lái)負(fù)責(zé)管理系統(tǒng)內(nèi)部類的調(diào)用,并為表示層提供了一個(gè)單一而簡(jiǎn)單的接口。這個(gè)Façade對(duì)象,在我們的Duwamish的設(shè)計(jì)中,就是BusinessFacade(業(yè)務(wù)外觀)層。
以下是Duwamish的結(jié)構(gòu)關(guān)系圖:
我們從圖中可以清楚的看到,瀏覽器首先調(diào)用的是表示層WEB,然后WEB將請(qǐng)求發(fā)送給業(yè)務(wù)外觀層,業(yè)務(wù)外觀層對(duì)請(qǐng)求進(jìn)行初步的處理,判斷是否需要調(diào)用業(yè)務(wù)規(guī)則層,還是直接調(diào)用數(shù)據(jù)訪問層獲取數(shù)據(jù)。最后由數(shù)據(jù)訪問層訪問數(shù)據(jù)庫(kù)并按照來(lái)時(shí)的步驟返回結(jié)果到瀏覽器(對(duì)于圖中涉及到其它的結(jié)構(gòu)模塊以后會(huì)分別予以詳細(xì)介紹)。
代碼示例:
以下是兩種不同處理路徑的代碼示例:
獲取商品目錄
表示層調(diào)用業(yè)務(wù)外觀層:
productSystem = new ProductSystem();
categorySet = productSystem.GetCategories(categoryID);
業(yè)務(wù)外觀層直接調(diào)用數(shù)據(jù)層:
public CategoryData GetCategories(int categoryId){if ( dsCommand == null ){throw new System.ObjectDisposedException( GetType().FullName );}return FillCategoryData("GetCategories", "@CategoryId", categoryId);}
添加定單
表示層調(diào)用業(yè)務(wù)外觀層:
public void AddOrder(){ApplicationAssert.CheckCondition(cartOrderData != null, "Order requires data",ApplicationAssert.LineNumber);ApplicationLog.WriteTrace("Duwamish7.Web.Cart.AddOrder:\r\nCustomerId: " +cartOrderData.Tables[OrderData.CUSTOMER_TABLE].Rows[0][OrderData.PKID_FIELD].ToString());cartOrderData = (new OrderSystem()).AddOrder(cartOrderData);}
業(yè)務(wù)外觀層調(diào)用業(yè)務(wù)規(guī)則層:
public OrderData AddOrder(OrderData order){ApplicationAssert.CheckCondition(order != null, "Order is required",ApplicationAssert.LineNumber);(new BusinessRules.Order()).InsertOrder(order);return order;}
業(yè)務(wù)規(guī)則層調(diào)用數(shù)據(jù)層:
public bool InsertOrder(OrderData order){//此處省略復(fù)雜的處理邏輯if ( isValid ){using (DataAccess.Orders ordersDataAccess = new DataAccess.Orders()){return (ordersDataAccess.InsertOrderDetail(order)) > 0;}}elsereturn false;}
總結(jié):
通過分析Duwamish7的結(jié)構(gòu)設(shè)計(jì),我們掌握了Façade模式,并學(xué)習(xí)到了如何通過Façade模式對(duì)應(yīng)用結(jié)構(gòu)進(jìn)行改進(jìn),同時(shí)了解了Duwamish7的基本概念和處理流程,為以后深入分析和學(xué)習(xí)Duwamish7的的其它部分打下了一個(gè)基礎(chǔ)