當前位置:工程項目OA系統(tǒng) > 泛普服務體系 > 泛普博客
Java EE開發(fā)三劍客現(xiàn)狀和發(fā)展淺析
JSF 2.0
盡管 Java 在展示層框架上競爭的非常激烈,但 JSF 仍然固守著自己的領地。雖然有很多關于 JSF 的易用性和健壯性的質疑聲,但 JSF2.0 就是為正面解決這些問題而提出來的,它的易用,創(chuàng)新以及可擴展的特性包括:
JSF 正式將 Facelets 作為視圖技術。也許你不熟悉 Facelets ,它也是一個與 JSF 結合默契的開源視圖技術。因此,與 JSP 不同的是 Facelets 更適合 JSF 的組件模型以及生命周期的概念。當然,也許 Facelets 最強大的特性就是在用 mark-up 來代替 java 代碼創(chuàng)建自定義的組件。創(chuàng)建自定義組件的復雜度也許是開發(fā)者對 JSF 抱怨最多的地方了。
JSF2.0 通過使用標簽為 Java EE 5 提供了基于 annotation 驅動的配置特性(比如說可以使用 @ManagedBean 和 @ManagedProperty )。這也意味著可以一定程度上的減少 faces-config.xml 文件的大小,不過像在 navigation 這些結點的配置在 XML 文件還是不能少。
JSF2.0 為適應 AJAX 而改變了自身的生命周期,只需要局部頁面的交由 AJAX 事件處理。這個特性使得 JSF+AJAX 的組合更加自然。
JSF2.0 現(xiàn)在內置了優(yōu)秀的資源處理器。對 images , JavaScript 文件以及 CSS 樣式等都表現(xiàn)出眾。它可以對通過邏輯名稱,資源分組以及版本等方式來更好的引用資源。
除上述特性外, JSF2.0 還包括許多其它方便的改變。比如說支持事件,支持 RAILS_ENV 的開發(fā)風格 ( 就是 ROR) ,支持對標準組件集進行擴展。
EJB 3.1
EJB 在 Java EE 5 就已經經歷過了非常大的改動。也許看似不可能,但實際上 EJB3.0 還是在社區(qū)中廣泛得到認可,并且采納它的人也在不斷增長。而這一切也許是因為我們過度的認為需要怎么怎么簡化 Java EE 5 才取得這樣的成績。比如說,對 JBoss Seam 的興趣和 GlassFish 的熱情都是重要的關鍵因素。 EJB3.1 的目標就是在增加業(yè)務組件時,繼續(xù)讓 EJB 變得盡可能簡單。下面是對 EJB3.1 特性的高度概括:
原本需要甚至實現(xiàn) Session Beans 的業(yè)務接口變得可選了,不再強迫要求實現(xiàn)。在使用 Session Beans+JSF+WebBeans 的場景下尤其有用。
EJB3.1 增加了 Singleton Beans 的概念。因為人們更傾向于管理共享的應用程序狀態(tài),需要保證是完全線程安全的模型。此外, EJB3.1 新增的聲明式的并發(fā)控制也更加靈活。
EJB3.1 一個可圈可點的的強大特性就是支持 cron 風格的 scheduling 。除目前基于 timer API 的調度計時器外,聲明式和編程式的 cron 風格的 scheduling API 也加入了進來。
另一個強大的特性就是可以通過使用 @Asynchronous 標注來對 Session Bean 的方法進行異步調用。你甚至還通過它來控制異步 EJB 方法從而返回一個 java.util.concurrent.Future 對象。
EJB3.1 Lite 概念的逐漸引入形成了一個 EJB API 的子集,并在 Web Profile 中得到應用。只不過 EJB Lite 包含了像事務處理和安全這樣的特性,而那些消息機制,遠程調用以及 scheduling 等非必須的自然沒有必要加入其中。除上述列表所述特性外,
EJB3.1 的特性還包括:括直接將 EJB 打包成 war 文件,可運行在 embedded 的容器中便于 Java SE 環(huán)境進行 JUnit 測試,使用統(tǒng)一的標準化全局 JNDI 命名方式。
JPA 2.0
到 Java EE 6 的時候, JPA 已經徹底從 EJB 中分離,形成自己的體系 (EJB3.0 已經將 JPA 分離出去了 ) 。 JPA 的成功是毫無疑問的。它廣泛得到社區(qū)的采納和一流供應商的支持。本來我們擔心 EJB2.* 的 Enity Beans 垮臺可能無法讓 Java EE 再次引領持久層的標準,一個重要成功的因素就是 Gaving King 和 JBoss 社區(qū)毫不含糊的支持。 JPA2.0 的目標就是要在這次成功的基礎上再接再厲,填補更多的空白,再創(chuàng)多的創(chuàng)新:
JPA2.0 加入了大量必須的 ORM 映射增強特性,包括:支持通過使用 @ElementCollection 標注來增強 collections, maps 和 lists( 這里不是指實體之間的關聯(lián)關系 ) 集合,支持 map 的單向 one-to-many 關聯(lián) (JPA1.0 只允許雙向 one-to-many 關聯(lián) ) 。
EntityManager 和 Query API 都得到改進。比如說,現(xiàn)在可以從結果集中直接取得第一條記錄 (JPA1.0 只允許從一個 unique 結果集中反回單個記錄 ) ,指定 query 結果集的最大值,訪問各個供應商的底層實體對象 manager 或 query ,最后就是加入悲觀鎖 (JPA1.0 只支持樂觀鎖 ) 。
JPQL 也提供類似于 SQL 的 CASE , NULLIF , COALESCE 等函數(shù) 。
JPA2.0 應廣大開發(fā)者要求增加了 Criteria API 。要是你對 Hibernate 或 TopLink 的 Criteria API 不熟悉的話,可以將它想像成一個以 Java 為中心的面向對象,線程安全并可以與 JPQL 劃上等號的一組 API 。這組 API 適合于編寫復雜的動態(tài)查詢語句,還可避免解析 JPQL 語句時,所拋出的運行期異常。
更完整的 JAP2.0 特性還包括:標準的二級緩存,標準的 JDBC properties ,指定超時時間等等。(來自互聯(lián)網)
- 12008北京奧運會票務嚴峻考驗IT容量
- 2解決服裝店庫存積壓的方法及思路
- 32005年度最佳CRM實施獲獎企業(yè)名單揭曉
- 4戒定慧與企業(yè)的核心競爭力
- 5概說《三國演義》
- 6網管員如何排除無線路由器的電磁干擾
- 7網管員基礎知識:ADSL加速方法全分析
- 8[服裝管理軟件]如何讓服裝店訂貨更加科學
- 9泛普軟件告訴您OA系統(tǒng)和招標業(yè)務管理系統(tǒng)的差異
- 10做企業(yè)剎車比加油更安全
- 11貨運資格證
- 12戰(zhàn)國時代的CRM市場
- 13寧夏啟動全民健身狀況調查
- 14當OA辦公軟件系統(tǒng)遇上微信,未來整合趨勢大
- 15企業(yè)OA系統(tǒng)優(yōu)化資源配置體現(xiàn)在辦公管理中
- 16營銷老總應該具有的八項修為
- 17廣東連鎖50強深穗莞三分天下
- 18信息系統(tǒng)項目成本估算的難點
- 19三線城市創(chuàng)業(yè)潮
- 20洗臉能解決不同的肌膚問題?新時代美容
- 21實施和推廣OA應用的企業(yè)在前期需要關心的問題
- 22網管軟件能幫助企業(yè)實現(xiàn)“零故障”嗎?
- 23八大美院 遼寧藝術類高考志愿填報指導
- 24競爭情報的內涵與搜集途徑
- 25創(chuàng)新帶動成長,凝聚發(fā)展力量
- 26棱鏡事件讓硅谷企業(yè)遭遇“滑鐵盧”
- 27重慶OA系統(tǒng)專家淺析OA系統(tǒng)的應用實施
- 28用市場化的眼光看ITIL管理軟件
- 29平臺型化的OA辦公軟件擁有其良好的技術架構
- 30怎樣進行完善的CRM配置