APEX
總體來說,APEX是我見過最便捷最高效的開發框架,用起來比PHP還舒服。上手簡單,學習成本極低,曾經有個做行政的小女生,在我指導下兩天就可以開發出簡單的審批管理站點。如果企業要做一些內部應用,APEX是上上之選。
相比起我用過的其他框架,有兩個特點是APEX獨一無二的:
在線編輯,無桌面IDE。
使用SQL和PL/SQL語言開發。
下圖是APEX開發界面:
APEX依靠數據庫來執行業務邏輯及生成html頁面。頁面的各種布局、控件模板是存儲在數據庫里的,一個Oracle數據再加一個http server就它所有的東西了,如果使用數據庫的PL/SQL Gateway,甚至連獨立的http server都不需要。所以物理上APEX就是Oracle數據庫的一部分,最近版本的Oracle數據庫都帶有APEX,默認情況下會隨數據庫一起安裝。
APEX沒有專門的數據訪問層,數據操作直接用SQL。一方面是簡單,另一方面因為是數據庫環境中在線開發,可以直接讀取數據庫對象,SQL大多是半自動化生成。后臺業務邏輯用PL/SQL實現,Oracle的package足夠強大,實在不行Oracle數據庫還帶有jvm,寫java代碼也行;或者它也支持web service,可以調用外部模塊。
UI方面,非常的MVC化。M包括保存數據的item,V用html模板生成布局和控件,C負責計算、驗證、數據處理、導航等。APEX界面元素包含了常用的list、form、chart、button及各種輸入控件,并且可以自己建plugin,或者用第三方的plugin,甚至可以加入extjs這種js框架。但作為便捷框架,我不提倡做深度自定義開發。form + list其實已經能滿足絕大部分應用了,像Siebel這種大型系統的 applet也就那么幾種。
下圖是APEX應用樣式:
APEX還帶有幾十種打包的應用程序,比如項目管理、issue跟蹤、報表等,可以快速部署。
費用方面,APEX本身不需求額外的license,如果采購了Oracle的數據庫,就可以直接用APEX。如果沒有,APEX還支持Oracle XE數據庫。
[page]ADF
ADF有兩大特色:
一是豐富的RIA組件,ADF有上百種UI組件。順便說一下,我不是專門做前端的,接觸過的RIA框架包括ADF、RichFaces、ExtJs、Dojo、JQuery UI等,但能給我驚艷感的只有ADF和ExtJs。也不是說其他的框架不好,只不過是后來視野開拓了,也就沒啥感覺了。
二是可視化、聲明式的開發方式,說白了就是在JDeveloper這個IDE中拖拖控件就能自動生成配置文件和代碼。除了復雜的邏輯處理要寫代碼外,ADF將頁面設計、導航、模型層數據綁定、數據持久層的操作都實現了控件化。在ADF之前,類似的技術我只做過ASP.NET開發,記得當年.Net 3.5剛用上Linq to SQL時還興奮了好一陣,后來用上ADF,才知道一山還有一山高。
ADF的技術架構分三部分,如下圖:
ADF最上面的是ADF Faces和ADF Controller,這部分是基于JSF的技術。ADF Faces有上百種UI組件,大量使用了Ajax特性;組件內的facet嵌套其他組件可以添加更多功能;提供客戶端和服務端API。ADF Controller對JSF Controller進行了擴展,首先是Task Flow增強了JSF導航控制,其次還對JSF的Lifecycle和Managed Bean Scope進行了增強。
ADF最下面是ADF Business Components(簡稱ADF BC),負責業務邏輯及ORM。
ADF Controller和ADF BC之間是ADF Model。ADF Model將ADF BC封裝后暴露給UI使用,實現數據控制和數據綁定。除了ADF BC,ADF Model還支持EJB、Web Service等。
ADF使用類似AM-MVC的模式,在現在看來還是相當先進的。配合JDeveloper,開發過程極其流暢,確如我最初看到的教學視頻那樣,有些應用幾乎可以做到無代碼開發。
雖然ADF看上去似乎很美好,但我用下來覺得坑也不少。第一,ADF算是比較復雜的框架,它自身的文檔就有上千頁,但還不夠,還需要了解一些JSF的基礎知識。它屬于那種表面上看上去很傻瓜,走下去才發現岔路越來越多,需要很長時間邊學習邊摸索,才能形成正確的開發模式和規范,即所謂的best practice。第二,對Java EE新版本支持問題。ADF是基于JSF的(ADF BC不算),但還停留在十年前JSF 1.2的時代,申明式開發大量使用xml配置文件(Java EE 6基本只用Annotation),還在使用JSF Managed Bean(Java EE 6是CDI Bean)。盡管ADF自成體系,但Java EE 6、7陸續加入的新功能和先進的開發模式都沒法用上,實在是可惜。第三,ADF的開發環境還有待改進,JDeveloper占用資源比較多,特別是可視化的編輯界面,復雜的頁面用i7的cpu還會卡頓。第四,還有bug。盡管這幾年經過11g、12c中間好幾個版本,但bug還是有。最新的12.1.3我還碰到了,甘特圖的子任務顯示問題,浪費了兩天時間,無果,最終放棄。
所以,對想嘗試ADF的朋友,我的忠告是堅持用上兩個月,再判斷它是否適合你。學習ADF另一個好處就是以后可以做Oracle其他應用的開發,Oracle已經把ADF作為它戰略性開發框架,很多產品線已經替換成了ADF樣式的界面。比如說SOA Suite中的Human Task就需要用ADF開發。
費用方面,ADF本身是免費的,但它只能部署到Weblogic,Weblogic不是免費的(跟APEX一個道理)。如果你想部署到免費的Application Server,比如Glassfish、Tomcat,用ADF Essential,ADF Essential閹割了Security這塊,需要找自己解決或找第三方的方案。此外,還有個開源的、簡化版本的ADF Faces捐獻給Apache MyFaces。
ADF有三個比較有特色的兄弟,順便介紹下:
1. JHeadstart – 根據模板生成ADF程序,簡化開發工作。特別適合那些對界面設計沒啥經驗、太多組件導致選擇恐懼癥的人。
2. ADF Desktop Integration(簡稱ADF DI) - 前端這部分不用ADF Faces的Web界面,而是作為一個插件整合到Excel中,類似于C/S架構。因為企業內部有很多數據處理的工作,Excel比Web界面有優勢。
3. Mobile Application Framework(簡稱MAF) - hybrid移動應用開發框架,支持iOS和Andriod系統。跟IBM Worklight的hybrid框架類似,MAF應用像原生應用安裝在設備上,但內部打包了一個JVM執行Java代碼,用移動設備內部的瀏覽器顯示 UI,用Apache Cordova調用設備內部的攝像頭、GPS等服務。