對(duì)于Struts和Spring兩種MVC框架的比較
基于Web的MVC framework在J2EE的世界內(nèi)已是空前繁榮。TTS網(wǎng)站上幾乎每隔一兩個(gè)星期就會(huì)有新的MVC框架發(fā)布。目前比較好的MVC,老牌的有Struts,Webwork。新興的MVC框架有Spring MVC,Tapestry,JSF等。這些大多是著名團(tuán)隊(duì)的作品,另外還有一些邊緣團(tuán)隊(duì)的作品,也相當(dāng)出色,如Dinamica,VRaptor等。這些框架都提供了較好的層次分隔能力。在實(shí)現(xiàn)良好的MVC分隔的基礎(chǔ)上,提供一些現(xiàn)成的輔助類庫,同時(shí)也促進(jìn)了生產(chǎn)效率的提高。如何選擇一個(gè)好的框架應(yīng)用在項(xiàng)目設(shè)計(jì)中,將會(huì)對(duì)項(xiàng)目的效率和可重用具有至關(guān)重要性。
2 Struts框架
Struts是Apache軟件基金Jakarta項(xiàng)目的一部分。Struts框架的主要架構(gòu)設(shè)計(jì)和開發(fā)者是Craig R.McClanahan。Struts是目前Java Web MVC框架中不爭的王者。經(jīng)過長達(dá)五年的發(fā)展,Struts已逐漸成長為一個(gè)穩(wěn)定、成熟的框架,并占有MVC框架最大的市場份額。但Struts某些技術(shù)特性已經(jīng)落后于新興的MVC框架。面對(duì)Spring MVC,Webwork2這些設(shè)計(jì)更精密,擴(kuò)展性更強(qiáng)的框架,Struts受到了前所未有的挑戰(zhàn)。但就產(chǎn)品開發(fā)的角度,Struts仍然是最穩(wěn)妥的選擇。
Struts由一組相互協(xié)作的類(組件),Serlvet以及jsp tag lib組成。基于Stmts構(gòu)架的Web應(yīng)用程序基本上符合JSPModel2的設(shè)計(jì)標(biāo)準(zhǔn),是MVC設(shè)計(jì)模式的一種變化類型。根據(jù)對(duì)framework的描述,很容易理解為什么說Struts是一個(gè)Web framwork,而不僅僅是一些標(biāo)記庫的組合。但Struts也包含了豐富的標(biāo)記庫和獨(dú)立于該框架工作的實(shí)用程序類。Struts有其自己的控制器(Controller),同時(shí)整合了其他的一些技術(shù)去實(shí)現(xiàn)模型層(Model)和視圖層(View)。在模型層,Struts可以很容易的與數(shù)據(jù)訪問技術(shù)相結(jié)合,包括EJB,JDBC和Obiect Relation Bridge。在視圖層,Struts能夠與JSP,VelocityTemplares,XSL等等這些表示層組件相結(jié)合。
Struts的體系結(jié)構(gòu),Struts framework是MVC模式的體現(xiàn),分別從模型、視圖、控制描述struts的體系結(jié)構(gòu)(Architec-ture)。
(1)從視圖角度(View)主要由JSP建立,Struts自身包含了一組可擴(kuò)展的自定義標(biāo)簽庫(TagLib),可簡化創(chuàng)建用戶界面的過程。目前包括:Bean Tags,HTML Tags,Logic Tags,Nested Tags,Template Tags這幾個(gè)Taglib。有關(guān)其詳細(xì)資料請參考Struts用戶手冊。
(2)從模型角度(Model) 模型主要是表示一個(gè)系統(tǒng)的狀態(tài)(有時(shí)候,改變系統(tǒng)狀態(tài)的業(yè)務(wù)邏輯操作也劃分到模型中)。在Struts中,系統(tǒng)的狀態(tài)主要有ActiomForm Bean體現(xiàn),一般情況下,這些狀態(tài)是非持久性的。如果需要將這些狀態(tài)轉(zhuǎn)化為持久性數(shù)據(jù)存儲(chǔ),Struts本身也提供了Utitle包,可以方便與數(shù)據(jù)庫操作。
(3)從控制器角度(Controller) 在Struts framework中,Controller主要是ActionServlet,但是對(duì)于業(yè)務(wù)邏輯的操作則主要由Action,ActionMapping,ActionForward這幾個(gè)組件協(xié)調(diào)完成(也許這幾個(gè)組件,應(yīng)該劃分到模型中的業(yè)務(wù)邏輯一塊)。其中,Action扮演了真正的業(yè)務(wù)邏輯的實(shí)現(xiàn)者,而ActionMapping和ActionForward則指定了不同業(yè)務(wù)邏輯或流程的運(yùn)行方向。
對(duì)于Struts如何控制、處理客戶請求,通過對(duì)Struts的4個(gè)核心組件介紹來具體說明。這幾個(gè)組件是:ActionServlet;Action Classes;Action Mapping(此處包括ActionForward);ActionFrom Bean。
3 Spring框架
Spring實(shí)際上是《Expert One―on―One J2EE Design andDevelopment》一書中所闡述的設(shè)計(jì)思想的具體實(shí)現(xiàn)。在One―on一One一書中,Rod Johnson倡導(dǎo)J2EE實(shí)用主義的設(shè)計(jì)思想,并隨書提供了一個(gè)初步的開發(fā)框架實(shí)現(xiàn)(interface2l開發(fā)包)。而Spring正是這一思想的更全面和具體的體現(xiàn)。RodJohnson在interface21開發(fā)包的基礎(chǔ)之上,做了進(jìn)一步的改造和擴(kuò)充,使其發(fā)展為一個(gè)更加開放、清晰、全面、高效的開發(fā)框架。
Spring是一個(gè)開源框架,由Rod Johnson創(chuàng)建并且在其著作《J2EE設(shè)計(jì)開發(fā)編程指南》里進(jìn)行了描述。它是為了解決企業(yè)應(yīng)用開發(fā)的復(fù)雜性而創(chuàng)建。Spring使用基本的JavaBeans完成以前只可能由EJB完成的事情變得可能。然而,Spring的用途不僅限于服務(wù)器端的開發(fā)。從簡單性、可測試性和松耦合的角度,任何Java應(yīng)用都可以從Spting中受益。Spring是一個(gè)輕量的控制反轉(zhuǎn)和面向切面的容器框架。這些描述過于簡單。但的確概括出Spring。
(1)輕量從大小與開銷而言Spting都是輕量的。完整的Spring框架可在一個(gè)大小1 MB多的JAR文件里發(fā)布。并且Spring所需的處理開銷也是微不足道。此外,Spring是非侵入式的:典型地,Spring應(yīng)用中的對(duì)象不依賴于輕量。
(2)控制反轉(zhuǎn) Spring通過一種稱作控制反轉(zhuǎn)(IoC)的技術(shù)促進(jìn)了松耦合。當(dāng)應(yīng)用了IoC,對(duì)象被動(dòng)地傳遞它們的依賴而不是自己創(chuàng)建或者查找依賴對(duì)象??梢哉J(rèn)為IoC與JNDI相反,不是對(duì)象從容器中查找依賴,而是容器在對(duì)象初始化時(shí)不等被請求就將依賴傳遞給它。
(3)面向切面Spring包含對(duì)面向切面編程的豐富支持,允許通過分離應(yīng)用的業(yè)務(wù)邏輯與系統(tǒng)服務(wù)(例如審計(jì)與事物管理)進(jìn)行內(nèi)聚性的開發(fā)。應(yīng)用對(duì)象只做它們應(yīng)該做的,完成業(yè)務(wù)邏輯,僅此而已。并不負(fù)責(zé)(甚至是意識(shí))其它的系統(tǒng)關(guān)注點(diǎn),例如日志或事物支持。
(4)容器 Spring包含和管理應(yīng)用對(duì)象的配置和生命周期,在此意義上它是一種容器??梢耘渲妹總€(gè)bean如何被創(chuàng)建,基于一個(gè)配置原形為bean創(chuàng)建一個(gè)單獨(dú)的實(shí)例或每次需要時(shí)都生成一個(gè)新的實(shí)例以及它們是如何相互關(guān)聯(lián)的。然而,Spring不應(yīng)該被混同于傳統(tǒng)重量的EJB容器,它們經(jīng)常是龐大與笨重的,難以使用。
(5)框架Spring使由簡單的組件配置和組合復(fù)雜的應(yīng)用成為可能。在Spring中,應(yīng)用對(duì)象被聲明式地組合,典型地是在一個(gè)XML文件里,Spr4ng提供了很多基礎(chǔ)功能(事務(wù)管理、持久性框架集成等等),并留有應(yīng)用邏輯開發(fā)。
例如:Spring有3個(gè)重點(diǎn),一個(gè)是面向接口編程:一個(gè)是控制反轉(zhuǎn);另外一個(gè)就是依賴注入。有了控制反轉(zhuǎn)就有了聲明性的bean,在application.xml也就是Spring的核心配置文件里面聲明bean的屬性,對(duì)應(yīng)的類,引用名稱,這些是為編碼時(shí)要用到的bean做準(zhǔn)備的,對(duì)應(yīng)web應(yīng)用程序,Spring有專門的類SpringContextLoader,等等。另外在web.xml里可以用context-param子節(jié)點(diǎn)將application.xml納入范圍,這樣容器在加載web應(yīng)用時(shí),就將對(duì)應(yīng)的bean加載了,剩下的是如何引用這些bean的問題,這里用到Spring的接口注入,也是spring用的最多的依賴注入方式。例如:這有兩個(gè)類,一個(gè)是Main.java,一個(gè)是Demo.java.這里Main里面用到了Demo;
評(píng)論