基于
Web
的
MVC?framework
在
J2EE
的世界內已是空前繁榮。
TTS
網站上幾乎每隔一兩個星期就會有新的
MVC
框架發布。目前比較好的
MVC,
老牌的有
Struts
、
Webwork
。新興的
MVC?
框架有
Spring
?MVC
、
Tapestry
、
JSF
等。這些大多是著名團隊的作品,另外還有一些邊緣團隊的作品,也相當出色,如
Dinamica
、
VRaptor
等。這些框架都提供了較好的層次分隔能力。在實現良好的
MVC?
分隔的基礎上,通過提供一些現成的輔助類庫,同時也促進了生產效率的提高。
如何選擇一個好的框架應用在你的項目中,將會對你的項目的效率和可重用是至關重要的。本文將對目前最流行、最常用的兩種
framework
進行介紹。
一、
Struts
Struts
是
Apache
軟件基金下
Jakarta
項目的一部分。
Struts
框架的主要架構設計和開發者是
Craig?R.McClanahan
。
Struts?
是目前
Java?Web?MVC
框架中不爭的王者。經過長達五年的發展,
Struts
已經逐漸成長為一個穩定、成熟的框架,并且占有了
MVC
框架中最大的市場份額。但是
Struts
某些技術特性上已經落后于新興的
MVC
框架。面對
Spring?MVC
、
Webwork2?
這些設計更精密,擴展性更強的框架,
Struts
受到了前所未有的挑戰。但站在產品開發的角度而言,
Struts
仍然是最穩妥的選擇。
Struts
有一組相互協作的類(組件)、
Serlvet
以及
jsp?tag?lib
組成?;?/span>
struts
構架的
web
應用程序基本上符合
JSP?Model2
的設計標準,可以說是
MVC
設計模式的一種變化類型。根據上面對
framework
的描述,我們很容易理解為什么說
Struts
是一個
web?framwork
,而不僅僅是一些標記庫的組合。但
?Struts?
也包含了豐富的標記庫和獨立于該框架工作的實用程序類。
Struts
有其自己的控制器(
Controller
),同時整合了其他的一些技術去實現模型層(
Model
)和視
圖層
(
View
)。在模型層,
Struts
可以很容易的與數據訪問技術相結合,包括
EJB,JDBC
和
Object?Relation?Bridge
。在視圖層,
Struts
能夠與
JSP,?Velocity?Templates,XSL
等等這些表示層組件想結合。
Struts
的
體系結構
struts?framework
是
MVC?
模式的體現,下面我們就從分別從模型、視圖、控制來看看
struts
的體系結構(
Architecture
)。
?
從視圖角度(
View
)
主要由
JSP
建立,
struts
自身包含了一組可擴展的自定義標簽庫(
TagLib
),可以簡化創建用戶界面的過程。目前包括:
Bean?Tags
,
HTML?Tags
,
Logic?Tags
,
Nested?Tags
,
Template?Tags
這幾個
Taglib
。有關它們的詳細資料請參考
struts
用戶手冊
從模型角度(
Model
)
模型主要是表示一個系統的狀態(有時候,改變系統狀態的業務邏輯操作也也劃分到模型中)。在
Struts
中,系統的狀態主要有
ActiomForm?Bean
體現,一般情況下,這些狀態是非持久性的。如果需要將這些狀態轉化為持久性數據存儲,
Struts
本身也提供了
Utitle
包,可以方便的與數據庫操作
從控制器角度(
Controller
)
在
Struts?framework
中,
?Controller
主要是
ActionServlet
,但是對于業務邏輯的操作則主要由
Action
、
ActionMapping
、
ActionForward
這幾個組件協調完成(也許這幾個組件,應該劃分到模型中的業務邏輯一塊)。其中,
Action
扮演了真正的業務邏輯的實現者,而
ActionMapping
和
ActionForward
則指定了不同業務邏輯或流程的運行方向。
對于
Struts?
如何控制、處理客戶請求,讓我們通過對
struts
的四個核心組件介紹來具體說明。這幾個組件就是:
ActionServlet
。
Action?Classes
,
Action?Mapping
(此處包括
ActionForward
),
ActionFrom?Bean
。
二、
Spring
Spring?
實際上是
Expert?One-on-One?J2EE?Design?and?Development?
一書中所闡述的設計思想的具體實現。在
One-on-One?
一書中,
Rod?Johnson?
倡導
J2EE?
實用主義的設計思想,并隨書提供了一個初步的開發框架實現(
interface21?
開
發包
)。而
Spring?
正是這一思想的更全面和具體的體現。
Rod?Johnson?
在
interface21?
開發包的基礎之上,進行了進一步的改造和擴充,使其發展為一個更加開放、清晰、全面、高效的開發框架。
Spring
是一個開源框架,由
Rod?Johnson
創建并且在他的著作《
J2EE
設計開發編程指南》里進行了描述。它是為了解決企業應用開發的復雜性而創建的。
Spring
使使用基本的
JavaBeans
來完成以前只可能由
EJB
完成的事情變得可能了。然而,
Spring
的用途不僅限于服務器端的開發。從簡單性、可測試性和松耦合的角度而言,任何
Java
應用都可以從
Spring
中受益。
簡單來說,
Spring
是一個輕量的控制反轉和面向切面的容器框架。當然,這個描述有點過于簡單。但它的確概括出了
Spring
是做什么的。為了更好地理解
Spring
,讓我們分析一下這個描述:
?
1
、輕量,從大小與開銷兩方面而言
Spring
都是輕量的。完整的
Spring
框架可以在一個大小只有
1MB
多的
JAR
文件里發布。并且
Spring
所需的處理開銷也是微不足道的。此外,
Spring
是非侵入式的:典型地,
Spring
應用中的對象不依賴于輕量
??
從大小與開銷兩方面而言
Spring
都是輕量的。完整的
Spring
框架可以在一個大小只有
1MB
多的
JAR
文件里發布。并且
Spring
所需的處理開銷也是微不足道的。此外,
Spring
是非侵入式的:典型地,
Spring
應用中的對象不依賴于
Spring
的特定類。
2
、控制反轉
??Spring
通過一種稱作控制反轉(
IoC
)的技術促進了松耦合。當應用了
IoC
,對象被動地傳遞它們的依賴而不是自己創建或者查找依賴對象。你可以認為
IoC
與
JNDI
相反
??
不是對象從容器中查找依賴,而是容器在對象初始化時不等被請求就將依賴傳遞給它。
?
3
、面向切面
??Spring
包含對面向切面編程的豐富支持,允許通過分離應用的業務邏輯與系統服務(例如審計與事物管理)進行內聚性的開發。應用對象只做它們應該做的
??
完成業務邏輯
??
僅此而已。它們并不負責(甚至是意識)其它的系統關注點,例如
日志
或事物支持。
?
4
、容器
??Spring
包含和管理應用對象的配置和生命周期,在這個意義上它是一種容器。你可以配置你的每個
bean
如何被創建
??
基于一個配置原形為你的
bean
創建一個單獨的實例或者每次需要時都生成一個新的實例
??
以及它們是如何相互關聯的。然而,
Spring
不應該被混同于傳統的重量的
EJB
容器,它們經常是龐大與笨重的,難以使用。
?
框架:
Spring
使由簡單的組件配置和組合復雜的應用成為可能。在
Spring
中,應用對象被聲明式地組合,典型地是在一個
XML
文件里。
Spring
也提供了很多基礎功能(事務管理、持久性框架集成等等),將應用邏輯的開發留給了你。
?
所有
Spring
的這些特征使你能夠編寫更干凈、更可管理、并且更易于測試的代碼。它們也為
Spring
中的各種子框架提供了基礎。
凡是有該標志的文章,都是該blog博主Caoer(草兒)原創,凡是索引、收藏
、轉載請注明來處和原文作者。非常感謝。
|