Struts——MVC 的一種開放源碼實(shí)現(xiàn)外文資料翻譯(學(xué)生用).doc_第1頁
Struts——MVC 的一種開放源碼實(shí)現(xiàn)外文資料翻譯(學(xué)生用).doc_第2頁
Struts——MVC 的一種開放源碼實(shí)現(xiàn)外文資料翻譯(學(xué)生用).doc_第3頁
Struts——MVC 的一種開放源碼實(shí)現(xiàn)外文資料翻譯(學(xué)生用).doc_第4頁
Struts——MVC 的一種開放源碼實(shí)現(xiàn)外文資料翻譯(學(xué)生用).doc_第5頁
免費(fèi)預(yù)覽已結(jié)束,剩余16頁可下載查看

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

附件1:外文資料翻譯譯文StrutsMVC 的一種開放源碼實(shí)現(xiàn)本文介紹 Struts,它是使用 servlet 和 JavaServer Pages 技術(shù)的一種 Model View Controller 實(shí)現(xiàn)。Struts 可幫助您控制 Web 項(xiàng)目中的變化并提高專業(yè)化水平。盡管您可能永遠(yuǎn)不會(huì)用 Struts 實(shí)現(xiàn)一個(gè)系統(tǒng),但您可以將其中的一些思想用于您以后的 servlet 和 JSP 網(wǎng)頁的實(shí)現(xiàn)中。簡介小學(xué)生也可以在因特網(wǎng)上發(fā)布 HTML 網(wǎng)頁。但是,小學(xué)生的網(wǎng)頁和專業(yè)開發(fā)的網(wǎng)站有質(zhì)的區(qū)別。網(wǎng)頁設(shè)計(jì)人員(或者 HTML 開發(fā)人員)必須理解顏色、用戶、生產(chǎn)流程、網(wǎng)頁布局、瀏覽器兼容性、圖像創(chuàng)建和 JavaScript 等等。設(shè)計(jì)漂亮的網(wǎng)站需要做大量的工作,大多數(shù) Java 開發(fā)人員更注重創(chuàng)建優(yōu)美的對(duì)象接口,而不是用戶界面。JavaServer Pages (JSP) 技術(shù)為網(wǎng)頁設(shè)計(jì)人員和 Java 開發(fā)人員提供了一種聯(lián)系鈕帶。如果您開發(fā)過大型 Web 應(yīng)用程序,您就理解 變化 這個(gè)詞的含義?!澳P?視圖-控制器”(MVC) 就是用來幫助您控制變化的一種設(shè)計(jì)模式。MVC 減弱了業(yè)務(wù)邏輯接口和數(shù)據(jù)接口之間的耦合。Struts 是一種 MVC 實(shí)現(xiàn),它將 Servlet 2.2 和 JSP 1.1 標(biāo)記(屬于 J2EE 規(guī)范)用作實(shí)現(xiàn)的一部分。盡管您可能永遠(yuǎn)不會(huì)用 Struts 實(shí)現(xiàn)一個(gè)系統(tǒng),但了解一下 Struts 或許使您能將其中的一些思想用于您以后的 Servlet 的 JSP 實(shí)現(xiàn)中。 模型-視圖-控制器 (MVC)JSP 標(biāo)記只解決了部分問題。我們還得處理驗(yàn)證、流程控制和更新應(yīng)用程序的狀態(tài)等問題。這正是 MVC 發(fā)揮作用的地方。MVC 通過將問題分為三個(gè)類別來幫助解決單一模塊方法所遇到的某些問題:l Model(模型) 模型包含應(yīng)用程序的核心功能。模型封裝了應(yīng)用程序的狀態(tài)。有時(shí)它包含的唯一功能就是狀態(tài)。它對(duì)視圖或控制器一無所知。 l View(視圖) 視圖提供模型的表示。它是應(yīng)用程序的外觀。視圖可以訪問模型的讀方法,但不能訪問寫方法。此外,它對(duì)控制器一無所知。當(dāng)更改模型時(shí),視圖應(yīng)得到通知。 l Controller(控制器) 控制器對(duì)用戶的輸入作出反應(yīng)。它創(chuàng)建并設(shè)置模型。 l MVC Model 2Web 向軟件開發(fā)人員提出了一些特有的挑戰(zhàn),最明顯的就是客戶機(jī)和服務(wù)器的無狀態(tài)連接。這種無狀態(tài)行為使得模型很難將更改通知視圖。在 Web 上,為了發(fā)現(xiàn)對(duì)應(yīng)用程序狀態(tài)的修改,瀏覽器必須重新查詢服務(wù)器。另一個(gè)重大變化是實(shí)現(xiàn)視圖所用的技術(shù)與實(shí)現(xiàn)模型或控制器的技術(shù)不同。當(dāng)然,我們可以使用 Java(或者 PERL、C/C+ 或別的語言)代碼生成 HTML。這種方法有幾個(gè)缺點(diǎn):Java 程序員應(yīng)該開發(fā)服務(wù),而不是 HTML。 更改布局時(shí)需要更改代碼。 服務(wù)的用戶應(yīng)該能夠創(chuàng)建網(wǎng)頁來滿足它們的特定需要。 網(wǎng)頁設(shè)計(jì)人員不能直接參與網(wǎng)頁開發(fā)。 嵌在代碼中的 HTML 很難看。 對(duì)于 Web,需要修改標(biāo)準(zhǔn)的 MVC 形式。圖 4 顯示了 MVC 的 Web 改寫版,通常也稱為 MVC Model 2 或 MVC 2。Up data HTTP ResponseEvent HTTP RequestGetSet InstantiateModel(Bean)Provided by a backend service such as EJB serverClient BrowserController ServletViewJSP圖 4. MVC Model 2Struts,MVC 2 的一種實(shí)現(xiàn)Struts 是一組相互協(xié)作的類、servlet 和 JSP 標(biāo)記,它們組成一個(gè)可重用的 MVC 2 設(shè)計(jì)。這個(gè)定義表示 Struts 是一個(gè)框架,而不是一個(gè)庫,但 Struts 也包含了豐富的標(biāo)記庫和獨(dú)立于該框架工作的實(shí)用程序類。圖 5 顯示了 Struts 的一個(gè)概覽。DispatchForwardGetBusiness Logic ActionModelApplication StateController ServletViewJSPClient BrowserEvent HTTP RequestUp data HTTP ResponseStruts-config.xml圖 5. Struts 概覽Struts 概覽l Client browser(客戶瀏覽器) 來自客戶瀏覽器的每個(gè) HTTP 請求創(chuàng)建一個(gè)事件。Web 容器將用一個(gè) HTTP 響應(yīng)作出響應(yīng)。 l Controller(控制器) 控制器接收來自瀏覽器的請求,并決定將這個(gè)請求發(fā)往何處。就 Struts 而言,控制器是以 servlet 實(shí)現(xiàn)的一個(gè)命令設(shè)計(jì)模式。 struts-config.xml 文件配置控制器。 l 業(yè)務(wù)邏輯 業(yè)務(wù)邏輯更新模型的狀態(tài),并幫助控制應(yīng)用程序的流程。就 Struts 而言,這是通過作為實(shí)際業(yè)務(wù)邏輯“瘦”包裝的 Action 類完成的。 l Model(模型)的狀態(tài) 模型表示應(yīng)用程序的狀態(tài)。業(yè)務(wù)對(duì)象更新應(yīng)用程序的狀態(tài)。ActionForm bean 在會(huì)話級(jí)或請求級(jí)表示模型的狀態(tài),而不是在持久級(jí)。JSP 文件使用 JSP 標(biāo)記讀取來自 ActionForm bean 的信息。 l View(視圖) 視圖就是一個(gè) JSP 文件。其中沒有流程邏輯,沒有業(yè)務(wù)邏輯,也沒有模型信息 - 只有標(biāo)記。標(biāo)記是使 Struts 有別于其他框架(如 Velocity)的因素之一。 l 詳細(xì)分析 Struts圖 6 顯示的是 org.apache.struts.action 包的一個(gè)最簡 UML 圖。圖 6 顯示了 ActionServlet (Controller)、 ActionForm (Form State) 和 Action (Model Wrapper) 之間的最簡關(guān)系。ActionForward(from org.apache.struts.action)Action(from org.apache.struts.action)ActionServlet(from org.apache.struts.action)ActionForwards(from org.apache.struts.action)ActionForm(from org.apache.struts.action)ActionError(from org.apache.struts.action)ActionErrors(from org.apache.struts.action)Uses,createsUses,createsUses,createsUses,createsUses,createsUses,createscreatesusesusesusescreates#forwards 0.1#servlet 0.10.1 #servlet圖 6. Command (ActionServlet) 與 Model (Action & ActionForm) 之間的關(guān)系的 UML 圖ActionServlet 類 您還記得函數(shù)映射的日子嗎?在那時(shí),您會(huì)將某些輸入事件映射到一個(gè)函數(shù)指針上。如果您對(duì)此比較熟悉,您會(huì)將配置信息放入一個(gè)文件,并在運(yùn)行時(shí)加載這個(gè)文件。函數(shù)指針數(shù)組曾經(jīng)是用 C 語言進(jìn)行結(jié)構(gòu)化編程的很好方法?,F(xiàn)在好多了,我們有了 Java 技術(shù)、XML、J2EE,等等。Struts 的控制器是將事件(事件通常是 HTTP post)映射到類的一個(gè) servlet。正如您所料 - 控制器使用配置文件以使您不必對(duì)這些值進(jìn)行硬編碼。時(shí)代變了,但方法依舊。ActionServlet 是該 MVC 實(shí)現(xiàn)的 Command 部分,它是這一框架的核心。 ActionServlet (Command) 創(chuàng)建并使用 Action 、 ActionForm 和 ActionForward 。如前所述, struts-config.xml 文件配置該 Command。在創(chuàng)建 Web 項(xiàng)目時(shí),您將擴(kuò)展 Action 和 ActionForm 來解決特定的問題。文件 struts-config.xml 指示 ActionServlet 如何使用這些擴(kuò)展的類。這種方法有幾個(gè)優(yōu)點(diǎn): 應(yīng)用程序的整個(gè)邏輯流程都存儲(chǔ)在一個(gè)分層的文本文件中。這使得人們更容易查看和理解它,尤其是對(duì)于大型應(yīng)用程序而言。 網(wǎng)頁設(shè)計(jì)人員不必費(fèi)力地閱讀 Java 代碼來理解應(yīng)用程序的流程。 Java 開發(fā)人員也不必在更改流程以后重新編譯代碼。 可以通過擴(kuò)展 ActionServlet 來添加 Command 功能。 ActionForm 類 ActionForm 維護(hù) Web 應(yīng)用程序的會(huì)話狀態(tài)。 ActionForm 是一個(gè)抽象類,必須為每個(gè)輸入表單模型創(chuàng)建該類的子類。當(dāng)我說 輸入表單模型 時(shí),是指 ActionForm 表示的是由 HTML 表單設(shè)置或更新的一般意義上的數(shù)據(jù)。例如,您可能有一個(gè)由 HTML 表單設(shè)置的 UserActionForm 。Struts 框架將執(zhí)行以下操作: 檢查 UserActionForm 是否存在;如果不存在,它將創(chuàng)建該類的一個(gè)實(shí)例。 Struts 將使用 HttpServletRequest 中相應(yīng)的域設(shè)置 UserActionForm 的狀態(tài)。沒有太多討厭的 request.getParameter() 調(diào)用。例如,Struts 框架將從請求流中提取 fname ,并調(diào)用 UserActionForm.setFname() 。 Struts 框架在將 UserActionForm 傳遞給業(yè)務(wù)包裝 UserAction 之前將更新它的狀態(tài)。 在將它傳遞給 Action 類之前,Struts 還會(huì)對(duì) UserActionForm 調(diào)用 validation() 方法進(jìn)行表單狀態(tài)驗(yàn)證。 注: 這并不總是明智之舉。別的網(wǎng)頁或業(yè)務(wù)可能使用 UserActionForm ,在這些地方,驗(yàn)證可能有所不同。在 UserAction 類中進(jìn)行狀態(tài)驗(yàn)證可能更好。 可在會(huì)話級(jí)維護(hù) UserActionForm 。 注:struts-config.xml 文件控制 HTML 表單請求與 ActionForm 之間的映射關(guān)系。 可將多個(gè)請求映射到 UserActionForm 。 UserActionForm 可跨多頁進(jìn)行映射,以執(zhí)行諸如向?qū)е惖牟僮鳌?Action 類 Action 類是業(yè)務(wù)邏輯的一個(gè)包裝。 Action 類的用途是將 HttpServletRequest 轉(zhuǎn)換為業(yè)務(wù)邏輯。要使用 Action ,請創(chuàng)建它的子類并覆蓋 process() 方法。 ActionServlet (Command) 使用 perform() 方法將參數(shù)化的類傳遞給 ActionForm 。仍然沒有太多討厭的 request.getParameter() 調(diào)用。當(dāng)事件進(jìn)展到這一步時(shí),輸入表單數(shù)據(jù)(或 HTML 表單數(shù)據(jù))已被從請求流中提取出來并轉(zhuǎn)移到 ActionForm 類中。 注:擴(kuò)展 Action 類時(shí)請注意簡潔。 Action 類應(yīng)該控制應(yīng)用程序的流程,而不應(yīng)該控制應(yīng)用程序的邏輯。通過將業(yè)務(wù)邏輯放在單獨(dú)的包或 EJB 中,我們就可以提供更大的靈活性和可重用性。 考慮 Action 類的另一種方式是 Adapter 設(shè)計(jì)模式。 Action 的用途是“將類的接口轉(zhuǎn)換為客戶機(jī)所需的另一個(gè)接口。Adapter 使類能夠協(xié)同工作,如果沒有 Adapter,則這些類會(huì)因?yàn)椴患嫒莸慕涌诙鵁o法協(xié)同工作?!保ㄕ?Gof 所著的 Design Patterns - Elements of Reusable OO Software )。本例中的客戶機(jī)是 ActionServlet ,它對(duì)我們的具體業(yè)務(wù)類接口一無所知。因此,Struts 提供了它能夠理解的一個(gè)業(yè)務(wù)接口,即 Action 。通過擴(kuò)展 Action ,我們使得我們的業(yè)務(wù)接口與 Struts 業(yè)務(wù)接口保持兼容。(一個(gè)有趣的發(fā)現(xiàn)是, Action 是類而不是接口)。 Action 開始為一個(gè)接口,后來卻變成了一個(gè)類。真是金無足赤。) ActionMappings(from org.apache.struts.action)Action(from org.apache.struts.action)ActionServlet(from org.apache.struts.action)ActionMapping(from org.apache.struts.action)Uses,createsUses,createsUses,createsUses,createsUses,createsUses,createsuses#instance 0.10.1 #mappings#mappings 0.1#servlet 0.10.1 #servlet圖 7. Command (ActionServlet) 與 Model (Action) 之間的關(guān)系的 UML 圖Error 類 UML 圖(圖 6)還包括 ActionError 和 ActionErrors 。 ActionError 封裝了單個(gè)錯(cuò)誤消息。 ActionErrors 是 ActionError 類的容器,View 可以使用標(biāo)記訪問這些類。 ActionError 是 Struts 保持錯(cuò)誤列表的方式。 ActionMapping 類 輸入事件通常是在 HTTP 請求表單中發(fā)生的,servlet 容器將 HTTP 請求轉(zhuǎn)換為 HttpServletRequest ??刂破鞑榭摧斎胧录⒄埱蠓峙山o某個(gè) Action 類。 struts-config.xml 確定 Controller 調(diào)用哪個(gè) Action 類。 struts-config.xml 配置信息被轉(zhuǎn)換為一組 ActionMapping ,而后者又被放入 ActionMappings 容器中。(您可能尚未注意到這一點(diǎn),以 s結(jié)尾的類就是容器) ActionMapping 包含有關(guān)特定事件如何映射到特定 Action 的信息。 ActionServlet (Command) 通過 perform() 方法將 ActionMapping 傳遞給 Action 類。這樣就使 Action 可訪問用于控制流程的信息。 ActionMappings ActionMappings 是 ActionMapping 對(duì)象的一個(gè)集合。 Struts 的優(yōu)點(diǎn)l JSP 標(biāo)記機(jī)制的使用 標(biāo)記特性從 JSP 文件獲得可重用代碼和抽象 Java 代碼。這個(gè)特性能很好地集成到基于 JSP 的開發(fā)工具中,這些工具允許用標(biāo)記編寫代碼。 l 標(biāo)記庫 為什么要另發(fā)明一種輪子,或標(biāo)記庫呢?如果您在庫中找不到您所要的標(biāo)記,那就自己定義吧。此外,如果您正在學(xué)習(xí) JSP 標(biāo)記技術(shù),則 Struts 為您提供了一個(gè)起點(diǎn)。 l 開放源碼 您可以獲得開放源碼的全部優(yōu)點(diǎn),比如可以查看代碼并讓使用庫的每個(gè)人檢查代碼。許多人都可以進(jìn)行很好的代碼檢查。 l MVC 實(shí)現(xiàn)樣例 如果您希望創(chuàng)建您自己的 MVC 實(shí)現(xiàn),則 Struts 可增加您的見識(shí)。 l 管理問題空間 分治是解決問題并使問題可管理的極好方法。當(dāng)然,這是一把雙刃劍。問題越來越復(fù)雜,并且需要越來越多的管理。 Struts 的缺點(diǎn)l 仍處于發(fā)展初期 Struts 開發(fā)仍處于初級(jí)階段。他們正在向著發(fā)行版本 1.0 而努力,但與任何 1.0 版本一樣,它不可能盡善盡美。 l 仍在變化中 這個(gè)框架仍在快速變化。Struts 1.0 與 Struts 0.5 相比變化極大。為了避免使用不贊成使用的方法,您可能隔一天就需要下載最新的 Struts。在過去的 6 個(gè)月中,我目睹 Struts 庫從 90K 增大到 270K 以上。由于 Struts 中的變化,我不得不數(shù)次修改我的示例,但我不保證我的示例能與您下載的 Struts 協(xié)同工作。 l 正確的抽象級(jí)別 Struts 是否提供了正確的抽象級(jí)別?對(duì)于網(wǎng)頁設(shè)計(jì)人員而言,什么是正確的抽象級(jí)別呢?這是一個(gè)用 $64K 的文字才能解釋清楚的問題。在開發(fā)網(wǎng)頁的過程中,我們是否應(yīng)該讓網(wǎng)頁設(shè)計(jì)人員訪問 Java 代碼?某些框架(如 Velocity)說不應(yīng)該,但它提供了另一種 Web 開發(fā)語言讓我們學(xué)習(xí)。在 UI 開發(fā)中限制訪問 Java 有一定的合理性。最重要的是,如果讓網(wǎng)頁設(shè)計(jì)人員使用一點(diǎn) Java,他將使用大量的 Java。在 Microsoft ASP 的開發(fā)中,我總是看到這樣的情況。在 ASP 開發(fā)中,您應(yīng)該創(chuàng)建 COM 對(duì)象,然后編寫少量的 ASP 腳本將這些 COM 對(duì)象聯(lián)系起來。但是,ASP 開發(fā)人員會(huì)瘋狂地使用 ASP 腳本。我會(huì)聽到這樣的話,“既然我可以用 VBScript 直接編寫 COM 對(duì)象,為什么還要等 COM 開發(fā)人員來創(chuàng)建它呢?”通過使用標(biāo)記庫,Struts 有助于限制 JSP 文件中所需的 Java 代碼的數(shù)量。Logic Tag 就是這樣的一種庫,它對(duì)有條件地生成輸出進(jìn)行管理,但這并不能阻止 UI 開發(fā)人員對(duì) Java 代碼的狂熱。無論您決定使用哪種類型的框架,您都應(yīng)該了解您要在其中部署和維護(hù)該框架的環(huán)境。當(dāng)然,這項(xiàng)任務(wù)真是說起來容易做起來難。 l 有限的適用范圍 Struts 是一種基于 Web 的 MVC 解決方案,所以必須用 HTML、JSP 文件和 servlet 來實(shí)現(xiàn)它。 l J2EE 應(yīng)用程序支持 Struts 需要支持 JSP 1.1 和 Servlet 2.2 規(guī)范的 servlet 容器。僅憑這一點(diǎn)遠(yuǎn)不能解決您的全部安裝問題,除非使用 Tomcat 3.2。我用 Netscape iPlanet 6.0 安裝這個(gè)庫時(shí)遇到一大堆問題,按理說它是第一種符合 J2EE 的應(yīng)用程序服務(wù)器。我建議您在遇到問題時(shí)訪問 Struts 用戶郵件列表的歸檔資料(請參閱 參考資源)。 l 復(fù)雜性 在將問題分為幾個(gè)部分的同時(shí)也引入了復(fù)雜性。毫無疑問,要理解 Struts 必須接受一定的培訓(xùn)。隨著變化的不斷加入,這有時(shí)會(huì)令人很沮喪。歡迎訪問本網(wǎng)站。 Struts 的前景在這個(gè)軟件開發(fā)的新時(shí)代,一切都變得很快。在不到 5 年的時(shí)間內(nèi),我已經(jīng)目睹了從 cgi/perl 到 ISAPI/NSAPI、再到使用 VB 的 ASP、一直到現(xiàn)在的 Java 和 J2EE 的變遷。Sun 正在盡力將新的變化反映到 JSP/servlet 體系結(jié)構(gòu)中,正如他們對(duì) Java 語言和 API 所作的更改一樣。您可以從 Sun 的網(wǎng)站獲得新的 JSP 1.2 和 Servlet 2.3 規(guī)范的草案。此外,一個(gè)標(biāo)準(zhǔn) JSP 標(biāo)記庫即將出現(xiàn)。 附件2:外文原文(復(fù)印件)Strutsan open-source MVC implementationThis article introduces Struts, a Model-View-Controller implementation that uses servlets and JavaServer Pages (JSP) technology. Struts can help you control change in your Web project and promote specialization. Even if you never implement a system with Struts, you may get some ideas for your future servlets and JSP page implementation.IntroductionKids in grade school put HTML pages on the Internet. However, there is a monumental difference between a grade school page and a professionally developed Web site. The page designer (or HTML developer) must understand colors, the customer, product flow, page layout, browser compatibility, image creation, JavaScript, and more. Putting a great looking site together takes a lot of work, and most Java developers are more interested in creating a great looking object interface than a user interface. JavaServer Pages (JSP) technology provides the glue between the page designer and the Java developer. If you have worked on a large-scale Web application, you understand the term change. Model-View-Controller (MVC) is a design pattern put together to help control change. MVC decouples interface from business logic and data. Struts is an MVC implementation that uses Servlets 2.2 and JSP 1.1 tags, from the J2EE specifications, as part of the implementation. You may never implement a system with Struts, but looking at Struts may give you some ideas on your future Servlets and JSP implementations.Model-View-Controller (MVC)JSP tags solved only part of our problem. We still have issues with validation, flow control, and updating the state of the application. This is where MVC comes to the rescue. MVC helps resolve some of the issues with the single module approach by dividing the problem into three categories: Model The model contains the core of the applications functionality. The model encapsulates the state of the application. Sometimes the only functionality it contains is state. It knows nothing about the view or controller. View The view provides the presentation of the model. It is the look of the application. The view can access the model getters, but it has no knowledge of the setters. In addition, it knows nothing about the controller. The view should be notified when changes to the model occur. Controller The controller reacts to the user input. It creates and sets the model. MVC Model 2The Web brought some unique challenges to software developers, most notably the stateless connection between the client and the server. This stateless behavior made it difficult for the model to notify the view of changes. On the Web, the browser has to re-query the server to discover modification to the state of the application.Another noticeable change is that the view uses different technology for implementation than the model or controller. Of course, we could use Java (or PERL, C/C+ or what ever) code to generate HTML. There are several disadvantages to that approach: Java programmers should develop services, not HTML. Changes to layout would require changes to code. Customers of the service should be able to create pages to meet their specific needs. The page designer isnt able to have direct involvement in page development. HTML embedded into code is ugly. For the Web, the classical form of MVC needed to change. Figure 4 displays the Web adaptation of MVC, also commonly known as MVC Model 2 or MVC 2. Struts detailsDisplayed in Figure 6 is a stripped-down UML diagram of the org.apache.struts.action package. Figure 6 shows the minimal relationships among ActionServlet (Controller), ActionForm (Form State), and Action (Model Wrapper). Figure 6. UML diagram of the relationship of the Command (ActionServlet) to the Model (Action & ActionForm)The ActionServlet class Do you remember the days of function mappings? You would map some input event to a pointer to a function. If you where slick, you would place the configuration information into a file and load the file at run time. Function pointer arrays were the good old days of structured programming in C. Life is better now that we have Java technology, XML, J2EE, and all that. The Struts Controller is a servlet that maps events (an event generally being an HTTP post) to classes. And guess what - the Controller uses a configuration file so you don_t have to hard-code the values. Life changes, but stays the same. ActionServlet is the Command part of the MVC implementation and is the core of the Framework. ActionServlet (Command) creates and uses Action, an ActionForm, and ActionForward. As mentioned earlier, the struts-config.xml file configures the Command. During the creation of the Web project, Action and ActionForm are extended to solve the specific problem space. The file struts-config.xml instructs ActionServlet on how to use the extended classes. There are several advantages to this approach: The entire logical flow of the application is in a hierarchical text file. This makes it easier to view and understand, especially with large applications. The page designer does not have to wade through Java code to understand the flow of the application. The Java developer does not need to recompile code when making flow changes. Command functionality can be added by extending ActionServlet.The ActionForm class ActionForm maintains the session state for the Web application. ActionForm is an abstract class that is sub-classed for each input form model. When I say input form model, I am saying ActionForm represents a general concept of data that is set or updated by a HTML form. For instance, you may have a UserActionForm that is set by an HTML Form. The Struts framework will: Check to see if a UserActionForm exists; if not, it will create an instance of the class. Struts will set the state of the UserActionForm using corresponding fields from the HttpServletRequest. No more dreadful request.getParameter() calls. For instance, the Struts framework will take fname from request stream and call UserActionForm.setFname(). The Struts framework updates the state of the UserActionForm before passing it to the business wrapper UserAction. Before passing it to the Action class, Struts will also conduct form state validation by calling the validation() method on UserActionForm. Note: This is not always wise to do. There might be ways of using UserActionForm in other pages or business objects, where the validation might be different. Validation of the state might be better in the UserAction class. The UserActionForm can be maintained at a session level. Notes: The struts-config.xml file controls which HTML form request maps to which ActionForm. Multiple requests can be mapped UserActionForm. UserActionForm can be mapped over multiple pages for things such as wizards. The Action class The Action class is a wrapper around the business logic. The purpose of Action class is to translate the HttpServletRequest to the business logic. To use Action, subclass and overwrite the process() method. The ActionServlet (Command) passes the parameterized classes to ActionForm using the perform() method. Again, no more dreadful request.getParameter() calls. By the time the event gets here, the input form data (or HTML form data) has already been translated out of the request stream and into an ActionForm class. Figure 4. MVC Model 2Struts, an MVC 2 implementationStruts is a set of cooperating classes, servlets, and JSP tags that make up a reusable MVC 2 design. This definition implies that Struts is a framework, rather than a library, but Struts also contains an extensive tag library and utility classes that work independently of the framework. Figure 5 displays an overview of Struts. Figure 5. Struts overviewStruts overview Client browser An HTTP request from the client browser creates an event. The Web container will respond with an HTTP response. Controller The Controller receives the request from the browser, and makes the decision where to send the request. With Struts, the Controller is a command design pattern implemented as a servlet. The struts-config.xml file configures the Controller. Business logic The business logic updates the state of the model and helps control the flow of the application. With Struts this is done with an Action class as a thin wrapper to the actual business logic. Model state The model represents the state of the application. The business objects update the application state. ActionForm bean represents the Model state at a session or request level, and not at a persistent level. The JSP file reads information from the ActionForm bean using JSP tags. View The view is simply a JSP file. There is no flow logic, no business logic, and no model information - just tags. Tags are one of the things that make Struts unique compared to other frameworks like Velocity. Note: Think thin when extending the Action class. The Action class should control the flow and not the logic of the application. By placing the business logic in a separate package or EJB, we allow flexibility and reuse.Another way of thinking about Action class is as the Adapter design pattern. The purpose of the Action is to Convert the interface of a class into another interface the clients expect. Adapter lets classes work together that couldn_t otherwise because of incompatibility interface (from Design Patterns - Elements of Reusable OO Software by Gof). The client in this instance is the ActionServlet that knows nothing about our specific business class interface. Therefore, Struts provides a business interface it does

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論