Java-Android-jwebee
          Java-Android-jwebee
          對IT人來說,要成為一個優秀的技術型管理者,除了需要具備扎實的技術基礎之外,還應該培養良好的人際關系能力、談判與溝通技能、客戶關系與咨詢技能、商業頭腦和財務技能以及創新意識,此外還要有巧妙的激勵技巧和化解沖突與解決突發問題的能力.
          Java EE 5.0能取代Struts,Spring和Hibernate嗎?
          ?
          作者 :?Allen 文章來源 :?www.operamasks.org

          ???????? 2006 5 月, Java EE 5 規范正式發布。 Java EE 5 的出現,可能是 J2EE 誕生以來比較重量級的一次震撼 ,規范發布至今已有半年之多,業界對 Java EE 5 的關注也變得越來越熱烈, google 一下“ java ee ”關鍵字,可以得到 500 多萬條相關紀錄,而從 Sun 網站上進行檢索( http://java.sun.com/javaee/overview/compatibility.jsp ),也可以看到專業廠商已經迅速跟進,除 Sun 公司本身外,包括全球聞名的 SAP 、金蝶 Apusic 等另三家,已經推出全面支持 Java EE 5 規范的應用服務器產品。 ??

          Java EE 5 包含 JSF 1.2 EJB 3.0 JAX-WS 2.0 等新功能,試圖解決 Java 企業級應用開發的簡便性、靈活性及易用性問題。在 Java EE 5 出現之前,很多開源框架( Open Source Framework )如雨后春筍般涌現,嘗試從某種角度或某些方面去解決“委員會”規范所未能顧及的應用開發問題,如 Web 開發中的關注分離問題( MVC )、業務模型實現問題( ORM )等等。很多開源 framework 都非常出名,為人們喜愛并廣泛使用,如 Struts Spring Hibernate 等,這些“江湖派”作品曾經一定程度上成為 Java 企業級應用開發事實上的標準。 Java EE 5 的出現,是否會改變這種狀況?或者說,人們在重新選擇應用框架時,是否會優先考慮全新的 Java EE 5 技術?帶著這種疑問,筆者試圖進行簡單的技術比較,并輔于膚淺的評論,希望能夠拋磚引玉、借花獻佛,以娛大眾。

          ?

          Struts vs. JSF

          ?

          ?

          Struts

          JSF

          MVC

          支持

          支持

          POJO

          ?

          支持

          頁面流( Page Flow

          支持

          支持

          UI 組件( UI Component

          ?

          支持

          ?

          MVC 是模型( Model )、視圖( View )、控制( Controller )分層的結構,通過分層來實現關注分離,減少傳統開發中常見并重復的工作。 Struts JSF 均支持 MVC Struts MVC 支持的核心是 Controller ,通過 Controller (一個共同的入口 Servlet )獲得 HTTP 請求,將 HTTP 參數傳入 ActionForm ,然后將 ActionForm 傳給 Action Struts HTTP 請求只有一個事件處理 handler ,當請求過來時,由相應 Action 返回結果給前端 Controller ,并據此選擇如何進行導航。 JSF 一般也采用一個前端 Controller (有些商用 JSF 能夠智能識別 JSF 請求,無需額外的 controller ),不過在 Controller 中做的工作跟 Struts Controller 截然不同,它負責觸發 JSF 頁面組件中的事件,用 Render 工具生成組件的展現,綁定來自 Model 的數據到組件等。可以看到, JSF 在在控制層更靈活,在視圖層支持 Render 工具的變換而生成靈活的展現,在模型層實現與框架的徹底分離,因而具有更高的靈活性。 ?

          ?

          POJO 是無格式 Java 對象( Plain Old Java Object )。 POJO AOP 結合被廣泛用于快速業務模型。 Struts 設計的初衷主要是解決視圖和控制問題,并無過多關注模型的靈活性問題。 Struts 中的 ActionForm 模型必須繼承自框架類,雖然可以通過定制類庫提供一些幫助類實現模型與框架無關,但本質上還是緊耦合于 JSP- and HTTP-centric 方法 JSF 提供了對 POJO 天然的良好支持,并支持通過 RAD 工具實現快速的業務模型生成,從而具有更高的生產力。

          ?

          頁面導航的最大意義是幫助實現頁面的可視化開發,在 UI 界面上快速定義頁面流向。頁面導航分靜態導航和動態導航兩種,靜態導航是頁面直接流向另一頁面,動態導航是由特定動作或邏輯決定頁面的流向。 Struts JSF 均支持靜態和動態頁面導航。不過 Struts 中的導航規則是綁定到 Action 中的,那意味著可能需要對同一頁面中不同的 Action 做重復性的導航規則制定,而 JSF 導航可以跟 Action 無關,可以在頁面中不同組件的不同 Action 間共享相同的導航規則。

          ?

          Struts 本身并不提供 UI 組件機制,而 JSF 則提供了完整的 UI 組件機制。通過 UI 組件的定制和重用,能夠極大地簡化開發,提升用戶體驗。商業化的產品則往往更進一步,提供強大易用的開發工具,實現 drag-and-drop 方式所見即所得的 Web UI 開發。

          ?

          Spring vs. EJB 3.0

          ?

          ?

          ?

          Spring

          EJB3

          標準( Standard

          ?

          是, Java EE 5 標準組成部分

          持久( Persistence

          JDBC, Hibernate, JDO, iBatis and JPA ongoing spring 2.0

          JPA

          聲明式服務( Declarative Services

          支持

          支持

          依賴注入( Dependency Injection

          支持

          支持

          集群( Cluster

          ?

          支持

          ?

          Spring 框架是一個開源項目,并不是一個標準的東西。 Spring 自己定義了一套 XML 配置文件大綱以及程序接口,從長遠考慮,有很大的不確定性。 Spring 的主要開發者來自 Interface21 公司(這是幫我非常敬重的人), Interface21 靠相關咨詢和服務維持,作為一個商業團體其利益取向將可以完全左右 Spring 未來的方向。相比 EJB 3 出身名門正派的標準血統并有眾多主流商業廠商支持, Spring 的非標準性將可能帶來極大的風險。

          ?

          Spring 框架本身不帶持久實現,但它支持 JDBC, Hibernate, JDO iBatis 等持久化框架。 Spring 通過使用不同的 DAO Helper 類以利用 JDBC Hibernate iBatis JDO ,所以并沒有實現和最終服務提供者的隔離。簡單來說,就是需要重構代碼才能實現持久化框架的更換。 EJB 3.0 的持久集成在應用服務中,通過 JPA ,可以在底層更換持久實現,如將 Hibernate 更換為 Toplink EJB 3.0 的持久具有更大的靈活性,并有利于廠商進行性能優化和擴展。

          ?

          Spring EJB3.0 都為企業應用提供運行時服務,(如:事務、安全、日志消息、配置服務)。由于這些服務都不是直接與應用的業務邏輯相關聯,所以都不是由應用來自行管理。 EJB3.0 使用 Java 注釋來配置聲明式服務, Spring 使用 XML 配置文件。在大多數情況下, EJB3.0 的注釋聲明顯得更為簡單和優雅。 Spring 使用 XML 來定義屬性并配置聲明式服務的結果將是一個冗長而不穩定的配置文件。

          ?

          依賴注入模式( DI )是在應用中實現松散耦合的最佳實踐。 Spring EJB3.0 都支持 DI 模式,但他們有著深刻的不同。 Spring 支持通用的(但復雜的)基于 XML 配置文件的依賴注入 API EJB3.0 支持注入大多數服務對象(如 EJB 和上下文對象)和通過簡單注釋聲明的 JNDI 對象。

          ?

          EJB 3.0 完全支持集群。部署在服務集群中的 EJB3.0 應用將自動獲得負載均衡、分布緩存、狀態復制等功能。底層的集群服務隱藏在 EJB3.0 編程接口后面,屏蔽了所有的復雜性。 Spring 沒有簡單的利用集群的方法。

          ?

          Hibernate vs. EJB 3.0 ?

          ?

          Hibernate EJB 3.0 其實并沒有很好的可比性,因 Hibernate 僅關注 ORM ,而 ??? EJB 3.0 更多則更多表現為一種組件框架,其中包含 ORM 部分而已。 EJB 3.0 在設計過程中,曾經得益于 Hibernate 的作者 Gavin King ,據說 EJB 3.0 EntityBean 的設計理念完全來自于 Hibernate 。只需用將 EJB 3.0 EntityBean API 調用轉換為 Hibernate API Hibernate 就可以成為 EJB 3.0 EntityBean Implementation ? ?

          ?

          當開源 framework 已經成為習慣性勢力,并給人們帶來眾多樂趣或疲憊感的時候, Java EE 5 的出現會是適逢其時嗎?無論如何,是繼續選擇開源還是擁抱 Java EE 5 ?相信今天這并不是個容易的選擇,或許,隨著更多的廠商發布支持 Java EE 5 的產品,提供更好的工具支持,這個答案才會明朗起來。



          jwebee

          我的個人網站
          posted on 2007-01-05 18:29 周行 閱讀(359) 評論(0)  編輯  收藏 所屬分類: 評論
          Java-Android-jwebee
          主站蜘蛛池模板: 五大连池市| 专栏| 普洱| 甘孜| 临西县| 图木舒克市| 衡南县| 台湾省| 绥化市| 嫩江县| 涿鹿县| 黔江区| 社会| 普安县| 林西县| 靖州| 黄冈市| 托里县| 嘉祥县| 湖北省| 林甸县| 康乐县| 黄冈市| 武定县| 左云县| 武清区| 安泽县| 拉萨市| 旺苍县| 平舆县| 庄河市| 云霄县| 成都市| 石渠县| 博湖县| 保山市| 兴和县| 天长市| 巴彦县| 霍州市| 清新县|