???????? 2006
年
5
月,
Java EE 5
規(guī)范正式發(fā)布。
Java EE 5
的出現(xiàn),可能是
J2EE
誕生以來比較重量級的一次震撼
,規(guī)范發(fā)布至今已有半年之多,業(yè)界對
Java EE 5
的關(guān)注也變得越來越熱烈,
google
一下“
java ee
”關(guān)鍵字,可以得到
500
多萬條相關(guān)紀(jì)錄,而從
Sun
網(wǎng)站上進(jìn)行檢索(
http://java.sun.com/javaee/overview/compatibility.jsp
),也可以看到專業(yè)廠商已經(jīng)迅速跟進(jìn),除
Sun
公司本身外,包括全球聞名的
SAP
、金蝶
Apusic
等另三家,已經(jīng)推出全面支持
Java EE 5
規(guī)范的應(yīng)用服務(wù)器產(chǎn)品。
??
Java EE 5
包含
JSF 1.2
、
EJB 3.0
及
JAX-WS 2.0
等新功能,試圖解決
Java
企業(yè)級應(yīng)用開發(fā)的簡便性、靈活性及易用性問題。在
Java EE 5
出現(xiàn)之前,很多開源框架(
Open Source Framework
)如雨后春筍般涌現(xiàn),嘗試從某種角度或某些方面去解決“委員會”規(guī)范所未能顧及的應(yīng)用開發(fā)問題,如
Web
開發(fā)中的關(guān)注分離問題(
MVC
)、業(yè)務(wù)模型實現(xiàn)問題(
ORM
)等等。很多開源
framework
都非常出名,為人們喜愛并廣泛使用,如
Struts
、
Spring
、
Hibernate
等,這些“江湖派”作品曾經(jīng)一定程度上成為
Java
企業(yè)級應(yīng)用開發(fā)事實上的標(biāo)準(zhǔn)。
Java EE 5
的出現(xiàn),是否會改變這種狀況?或者說,人們在重新選擇應(yīng)用框架時,是否會優(yōu)先考慮全新的
Java EE 5
技術(shù)?帶著這種疑問,筆者試圖進(jìn)行簡單的技術(shù)比較,并輔于膚淺的評論,希望能夠拋磚引玉、借花獻(xiàn)佛,以娛大眾。
?
Struts vs. JSF
?
?
|
Struts
|
JSF
|
MVC
|
支持
|
支持
|
POJO
|
?
|
支持
|
頁面流(
Page Flow
)
|
支持
|
支持
|
UI
組件(
UI Component
)
|
?
|
支持
|
?
MVC
是模型(
Model
)、視圖(
View
)、控制(
Controller
)分層的結(jié)構(gòu),通過分層來實現(xiàn)關(guān)注分離,減少傳統(tǒng)開發(fā)中常見并重復(fù)的工作。
Struts
和
JSF
均支持
MVC
。
Struts
對
MVC
支持的核心是
Controller
,通過
Controller
(一個共同的入口
Servlet
)獲得
HTTP
請求,將
HTTP
參數(shù)傳入
ActionForm
,然后將
ActionForm
傳給
Action
類
。
Struts
對
HTTP
請求只有一個事件處理
handler
,當(dāng)請求過來時,由相應(yīng)
Action
返回結(jié)果給前端
Controller
,并據(jù)此選擇如何進(jìn)行導(dǎo)航。
JSF
一般也采用一個前端
Controller
(有些商用
JSF
能夠智能識別
JSF
請求,無需額外的
controller
),不過在
Controller
中做的工作跟
Struts Controller
截然不同,它負(fù)責(zé)觸發(fā)
JSF
頁面組件中的事件,用
Render
工具生成組件的展現(xiàn),綁定來自
Model
的數(shù)據(jù)到組件等。可以看到,
JSF
在在控制層更靈活,在視圖層支持
Render
工具的變換而生成靈活的展現(xiàn),在模型層實現(xiàn)與框架的徹底分離,因而具有更高的靈活性。
?
?
POJO
是無格式
Java
對象(
Plain Old Java Object
)。
POJO
與
AOP
結(jié)合被廣泛用于快速業(yè)務(wù)模型。
Struts
設(shè)計的初衷主要是解決視圖和控制問題,并無過多關(guān)注模型的靈活性問題。
Struts
中的
ActionForm
模型必須繼承自框架類,雖然可以通過定制類庫提供一些幫助類實現(xiàn)模型與框架無關(guān),但本質(zhì)上還是緊耦合于
JSP- and HTTP-centric
方法
。
JSF
提供了對
POJO
天然的良好支持,并支持通過
RAD
工具實現(xiàn)快速的業(yè)務(wù)模型生成,從而具有更高的生產(chǎn)力。
?
頁面導(dǎo)航的最大意義是幫助實現(xiàn)頁面的可視化開發(fā),在
UI
界面上快速定義頁面流向。頁面導(dǎo)航分靜態(tài)導(dǎo)航和動態(tài)導(dǎo)航兩種,靜態(tài)導(dǎo)航是頁面直接流向另一頁面,動態(tài)導(dǎo)航是由特定動作或邏輯決定頁面的流向。
Struts
和
JSF
均支持靜態(tài)和動態(tài)頁面導(dǎo)航。不過
Struts
中的導(dǎo)航規(guī)則是綁定到
Action
中的,那意味著可能需要對同一頁面中不同的
Action
做重復(fù)性的導(dǎo)航規(guī)則制定,而
JSF
導(dǎo)航可以跟
Action
無關(guān),可以在頁面中不同組件的不同
Action
間共享相同的導(dǎo)航規(guī)則。
?
Struts
本身并不提供
UI
組件機(jī)制,而
JSF
則提供了完整的
UI
組件機(jī)制。通過
UI
組件的定制和重用,能夠極大地簡化開發(fā),提升用戶體驗。商業(yè)化的產(chǎn)品則往往更進(jìn)一步,提供強大易用的開發(fā)工具,實現(xiàn)
drag-and-drop
方式所見即所得的
Web UI
開發(fā)。
?
Spring vs. EJB 3.0
?
?
?
|
Spring
|
EJB3
|
標(biāo)準(zhǔn)(
Standard
)
|
?
|
是,
Java EE 5
標(biāo)準(zhǔn)組成部分
|
持久(
Persistence
)
|
JDBC, Hibernate, JDO, iBatis and JPA
(
ongoing spring 2.0
)
|
JPA
|
聲明式服務(wù)(
Declarative Services
)
|
支持
|
支持
|
依賴注入(
Dependency Injection
)
|
支持
|
支持
|
集群(
Cluster
)
|
?
|
支持
|
?
Spring
框架是一個開源項目,并不是一個標(biāo)準(zhǔn)的東西。
Spring
自己定義了一套
XML
配置文件大綱以及程序接口,從長遠(yuǎn)考慮,有很大的不確定性。
Spring
的主要開發(fā)者來自
Interface21
公司(這是幫我非常敬重的人),
Interface21
靠相關(guān)咨詢和服務(wù)維持,作為一個商業(yè)團(tuán)體其利益取向?qū)⒖梢酝耆笥?/span>
Spring
未來的方向。相比
EJB 3
出身名門正派的標(biāo)準(zhǔn)血統(tǒng)并有眾多主流商業(yè)廠商支持,
Spring
的非標(biāo)準(zhǔn)性將可能帶來極大的風(fēng)險。
?
Spring
框架本身不帶持久實現(xiàn),但它支持
JDBC, Hibernate, JDO
和
iBatis
等持久化框架。
Spring
通過使用不同的
DAO
和
Helper
類以利用
JDBC
、
Hibernate
、
iBatis
或
JDO
,所以并沒有實現(xiàn)和最終服務(wù)提供者的隔離。簡單來說,就是需要重構(gòu)代碼才能實現(xiàn)持久化框架的更換。
EJB 3.0
的持久集成在應(yīng)用服務(wù)中,通過
JPA
,可以在底層更換持久實現(xiàn),如將
Hibernate
更換為
Toplink
。
EJB 3.0
的持久具有更大的靈活性,并有利于廠商進(jìn)行性能優(yōu)化和擴(kuò)展。
?
Spring
和
EJB3.0
都為企業(yè)應(yīng)用提供運行時服務(wù),(如:事務(wù)、安全、日志消息、配置服務(wù))。由于這些服務(wù)都不是直接與應(yīng)用的業(yè)務(wù)邏輯相關(guān)聯(lián),所以都不是由應(yīng)用來自行管理。
EJB3.0
使用
Java
注釋來配置聲明式服務(wù),
Spring
使用
XML
配置文件。在大多數(shù)情況下,
EJB3.0
的注釋聲明顯得更為簡單和優(yōu)雅。
Spring
使用
XML
來定義屬性并配置聲明式服務(wù)的結(jié)果將是一個冗長而不穩(wěn)定的配置文件。
?
依賴注入模式(
DI
)是在應(yīng)用中實現(xiàn)松散耦合的最佳實踐。
Spring
和
EJB3.0
都支持
DI
模式,但他們有著深刻的不同。
Spring
支持通用的(但復(fù)雜的)基于
XML
配置文件的依賴注入
API
。
EJB3.0
支持注入大多數(shù)服務(wù)對象(如
EJB
和上下文對象)和通過簡單注釋聲明的
JNDI
對象。
?
EJB 3.0
完全支持集群。部署在服務(wù)集群中的
EJB3.0
應(yīng)用將自動獲得負(fù)載均衡、分布緩存、狀態(tài)復(fù)制等功能。底層的集群服務(wù)隱藏在
EJB3.0
編程接口后面,屏蔽了所有的復(fù)雜性。
Spring
沒有簡單的利用集群的方法。
?
Hibernate vs. EJB 3.0
?
?
Hibernate
與
EJB 3.0
其實并沒有很好的可比性,因
Hibernate
僅關(guān)注
ORM
,而
??? EJB 3.0
更多則更多表現(xiàn)為一種組件框架,其中包含
ORM
部分而已。
EJB 3.0
在設(shè)計過程中,曾經(jīng)得益于
Hibernate
的作者
Gavin King
,據(jù)說
EJB 3.0 EntityBean
的設(shè)計理念完全來自于
Hibernate
。只需用將
EJB 3.0 EntityBean API
調(diào)用轉(zhuǎn)換為
Hibernate API
,
Hibernate
就可以成為
EJB 3.0
中
EntityBean
的
Implementation
。
?
?
?
當(dāng)開源
framework
已經(jīng)成為習(xí)慣性勢力,并給人們帶來眾多樂趣或疲憊感的時候,
Java EE 5
的出現(xiàn)會是適逢其時嗎?無論如何,是繼續(xù)選擇開源還是擁抱
Java EE 5
?相信今天這并不是個容易的選擇,或許,隨著更多的廠商發(fā)布支持
Java EE 5
的產(chǎn)品,提供更好的工具支持,這個答案才會明朗起來。
|