摘要:現(xiàn)在炒得正熱的Ajax其實(shí)是一種新瓶裝舊酒的過(guò)渡技術(shù),,相信未來(lái)一到兩年之內(nèi)將被新的技術(shù)所代替,,它解決問(wèn)題的方法與手段很難形成一種可高度抽象的框架級(jí)解決方案,,而JSF則是一種可擴(kuò)展的框架級(jí)解決方案,。在J2EE下一代規(guī)范Java EE 5.0中,JSF被放到了一個(gè)非常重要的地位,,J2EE社區(qū)試圖通過(guò)JSF來(lái)統(tǒng)一Web應(yīng)用的開(kāi)發(fā)模式" title="開(kāi)發(fā)模式">開(kāi)發(fā)模式與方法,。作為JCP組織成員的金蝶中間件,即將推出中國(guó)人作出的Apusic JSF…
?
前言
在J2EE下一代規(guī)范Java EE 5.0中,,JSF(Java Server Faces)技術(shù)被放到了一個(gè)非常重要的地位,。J2EE社區(qū)試圖通過(guò)JSF來(lái)統(tǒng)一Web應(yīng)用的開(kāi)發(fā)模式與方法。?
相對(duì)于傳統(tǒng)的基于JSP/Servlet的開(kāi)發(fā)模型,,JSF能夠帶來(lái)許多好處,,譬如:?
????????? 可定制的豐富的UI組件?
????????? 良好的事件響應(yīng)機(jī)制?
????????? 表達(dá)式語(yǔ)言(Expression Language)?
????????? 表單數(shù)據(jù)的自動(dòng)轉(zhuǎn)換與驗(yàn)證?
????????? 基于MVC的框架模型等等...?
但同時(shí)我們也不得不看到,業(yè)界常見(jiàn)的JSF引擎普遍存在著一些缺陷與不足(并不是說(shuō)JSF技術(shù)模型本身的局限,,而是常規(guī)的實(shí)現(xiàn)機(jī)制所產(chǎn)生的一些問(wèn)題),,而這些不足將可能對(duì)JSF成為日后Web應(yīng)用主流開(kāi)發(fā)技術(shù)" title="開(kāi)發(fā)技術(shù)">開(kāi)發(fā)技術(shù)帶來(lái)一定的負(fù)面影響,包括:?
????????? 常規(guī)的JSF實(shí)現(xiàn)機(jī)制,,運(yùn)行期性能并不是非常理想?
????????? 缺少良好的工具支持?
作為JCP組織成員,,金蝶中間件對(duì)待JSF技術(shù)又是如何思考的?是否打算對(duì)JSF進(jìn)行全面支持,?又是通過(guò)怎樣的解決方案來(lái)克服上述不足的呢,??
JSF與Ajax
一談到Web開(kāi)發(fā)技術(shù),就不得不提Ajax,。這是目前在整個(gè)IT界都紅得發(fā)紫的概念了,。在這里我想沒(méi)必要再去闡述一遍什么是Ajax,但我們可以對(duì)Ajax有一個(gè)基本的認(rèn)識(shí),。?
Ajax其實(shí)是一種新瓶裝舊酒的技術(shù),,它的好處是通過(guò)Java Script與DHTML,提供了一種異步編程模型,,從而使我們的Web應(yīng)用給客戶(hù)帶來(lái)更好的人機(jī)體驗(yàn),。但Ajax解決問(wèn)題的層面很低;或者說(shuō),,它解決問(wèn)題的方法與手段,,很難形成一種可高度抽象的框架級(jí)解決方案,而JSF則是一種可擴(kuò)展的框架級(jí)解決方案,。?
事實(shí)上,我認(rèn)為Ajax是一種過(guò)渡技術(shù),,相信在未來(lái)一到兩年之內(nèi)將被新的技術(shù)所代替,,是微軟的XAML,、Mozilla的XUL、還是任何可能的RIA標(biāo)準(zhǔn),,實(shí)際上整個(gè)業(yè)界都在觀望,。但不管采用什么技術(shù),JSF都能適應(yīng),,對(duì)JSF來(lái)說(shuō)適應(yīng)一個(gè)新技術(shù)只是更換一個(gè)Render Kit而已,。舉一個(gè)例子,如果想在網(wǎng)頁(yè)中實(shí)現(xiàn)圖表功能(Chart),,MSIE有VML,,Gecko和Opera有SVG,而在服務(wù)器端只需要簡(jiǎn)單地判斷一下瀏覽器類(lèi)型就可以選擇一個(gè)Render Kit生成不同的markup來(lái)完成相同的功能,,這是用常規(guī)JSP技術(shù)很難完成的任務(wù),。?
Apusic JSF:中國(guó)人做出的JSF引擎
容器級(jí)別的Ajax支持?
目前有JSF + Ajax這種思路的,恐怕也不是金蝶中間件一家,,但很多第三方" title="第三方">第三方的JSF + Ajax實(shí)現(xiàn)是提供一個(gè)組件庫(kù)以及一個(gè)附加的Servlet 或Filter來(lái)處理Ajax請(qǐng)求,,而我們是直接由JSF容器來(lái)處理Ajax請(qǐng)求的。我們會(huì)根據(jù)請(qǐng)求的類(lèi)型來(lái)判斷這是一個(gè)正常的HTTP請(qǐng)求還是一個(gè) Ajax請(qǐng)求,。如果是一個(gè)常規(guī)HTTP請(qǐng)求就運(yùn)行JSP頁(yè)面,,生成頁(yè)面文檔(并且我們會(huì)在生成的頁(yè)面文檔中嵌入Ajax所必須的Java Script代碼,后文提及),;如果該請(qǐng)求是一個(gè)Ajax請(qǐng)求,,服務(wù)器對(duì)請(qǐng)求參數(shù)正常解碼,并執(zhí)行JSF中除頁(yè)面輸出階段以外的所有其他階段,,這時(shí)將生成一個(gè)JSF的組件樹(shù),,遍歷該組件樹(shù),從中找出發(fā)生變化的數(shù)據(jù),,并將這些數(shù)據(jù)打包成一個(gè)Ajax應(yīng)答,,并由客戶(hù)端" title="客戶(hù)端">客戶(hù)端來(lái)更新這些修改的數(shù)據(jù),甚至改變頁(yè)面外觀,。 ?
在JSF規(guī)范中,,JSF頁(yè)面輸出階段所采用的Render Kit是可替換的,默認(rèn)的HTML_BASIC Render Kit輸出的是標(biāo)準(zhǔn)的HTML語(yǔ)法,,不包含任何Java Script代碼,,Apusic JSF引擎實(shí)現(xiàn)了一個(gè) AJAX Render Kit,可以在HTML文檔中嵌入Java Script代碼來(lái)實(shí)現(xiàn)Ajax特性,,而替換Render Kit只需要修改配置文件即可,。?
那么,這樣能夠帶來(lái)怎樣的好處呢,??
提升JSF運(yùn)行性能,,帶來(lái)更好的人機(jī)體驗(yàn),。?
常規(guī)JSF容器在狀態(tài)維護(hù)方面的通用做法是:基于Session的,或者基于請(qǐng)求傳遞型的,,這就意味著,,當(dāng)每進(jìn)行一次客戶(hù)端與服務(wù)器端的響應(yīng)時(shí),都需要把所有的狀態(tài)傳來(lái)傳去,,這無(wú)疑會(huì)對(duì)系統(tǒng)的運(yùn)行性能帶來(lái)較大的負(fù)面影響,,從而使開(kāi)發(fā)人員誤以為:JSF是一種重量級(jí)的技術(shù)模型。?
而通過(guò)Apusic JSF的Ajax特性,,我們能夠只把發(fā)生變化的數(shù)據(jù)打包成Ajax請(qǐng)求發(fā)送給服務(wù)器端,,而服務(wù)器端也只會(huì)將發(fā)生變化的數(shù)據(jù)打包成Ajax應(yīng)答,從而大大提升系統(tǒng)的運(yùn)行效率,。并且,,傳統(tǒng)的JSF請(qǐng)求應(yīng)答將刷新整個(gè)頁(yè)面,而Apusic JSF將只更新發(fā)生變化的客戶(hù)端組件,,從而給客戶(hù)帶來(lái)更好的人機(jī)體驗(yàn),。?
簡(jiǎn)化Ajax的開(kāi)發(fā)?
以前要寫(xiě)Ajax應(yīng)用要寫(xiě)很多Java Script代碼,開(kāi)發(fā),、調(diào)試,、維護(hù)這些 Script腳本都相當(dāng)煩瑣,如果采用Apusic JSF技術(shù),,你不再需要編寫(xiě)任何Java Script代碼,,引擎已經(jīng)幫你生成了這些代碼。Apusic JSF所有的標(biāo)準(zhǔn)組件都是支持Ajax的,,某些第三方組件可能本身并不支持 Ajax,,但使用一個(gè)名為
Apusic JSF還提供了一個(gè)名為
此外,我們還實(shí)現(xiàn)了一個(gè)
其它特性?
采用Apusic JSF還包含其它一些差異化特性,,包括:控件的換膚功能,,控件對(duì)IE、Mozilla(Firefox),、Opera等多瀏覽器的支持,,以及強(qiáng)大的布局功能等。?
?
<圖一? Windows 風(fēng)格的 Apusic JSF組件與布局> |
在<圖一>中所展示的是通過(guò)Apusic JSF生成的完全基于HTML, CSS, Java Script的界面,,它們和一個(gè)真正的窗口系統(tǒng)幾乎完全一樣,,包括移動(dòng)位置、改變堆疊順序,、以及模式對(duì)話(huà)框等,,但實(shí)際上他們都是“假”窗口。另外需要著重指出的是,,這里完全采用CSS布局,,避免了舊有的依賴(lài)于HTML Table嵌套的布局方式,從而使我們的程序具有更好的可維護(hù)性,。針對(duì)這樣一個(gè)界面,,我們可以觀察一下具體的實(shí)現(xiàn)代碼,以<圖一>中的Main Window為例:?
?? left='0' top='0' width='500' height='350'? ?? contentPaneStyleClass='normal-window'? ?? showIcon='true' showMinimize='true' showMaximize='true' showClose='true'? ?? onclose='window.location='index.html''>? ??
??
? ????? ????? ?? ?? <%@ include file='/WEB-INF/apusicjsf.inc' %>? |
我們發(fā)覺(jué),,通過(guò)Apusic JSF,,實(shí)現(xiàn)上述UI界面其實(shí)并不復(fù)雜,只需要通過(guò)簡(jiǎn)單的幾行代碼,,就能夠完成復(fù)雜的UI界面,。?
Apusic JSF還支持控件的換膚功能。以上述界面為例,,我們可以查看Mac OS風(fēng)格的界面樣式,,如圖二所示。?
?
<圖二? Mac OS 風(fēng)格的 Apusic JSF組件與布局示例> |
開(kāi)發(fā)工具" title="開(kāi)發(fā)工具">開(kāi)發(fā)工具的支持:Apusic Studio
在JSF規(guī)范中,,有這樣一句話(huà):“JSF is designed to be tooled”,。換言之,JSF規(guī)范從設(shè)計(jì)初開(kāi)始,,就非常強(qiáng)調(diào)對(duì)工具支持的依賴(lài),。幸運(yùn)的是,目前對(duì)JSF提供支持的開(kāi)發(fā)工具也逐漸豐富了起來(lái),,包括Oracle JDeveloper,、Sun Java Studio Creator等等,。金蝶中間件也同樣提供了一個(gè)基于Eclipse的集成式開(kāi)發(fā)環(huán)境:Apusic Studio,并通過(guò)該工具,,能夠給JSF的開(kāi)發(fā)帶來(lái)良好的支持,,包括:語(yǔ)法加亮、代碼輔助,、斷點(diǎn)調(diào)試,、可視化的設(shè)計(jì)等等。?
<圖三 Apusic Studio JSF 設(shè)計(jì)器> |

參考資料
注: Apusic應(yīng)用服務(wù)器,、Apusic Studio參見(jiàn)http://www.apusic.com?
作者鏈接:“影響中國(guó)軟件開(kāi)發(fā)的20人”袁紅崗部分(http://news.chinabyte.com/334/1760834_3.shtml)?
“人物:袁紅崗,所屬公司:金蝶中間件公司?
入選理由:最早開(kāi)發(fā)Windows上的企業(yè)應(yīng)用軟件,,打造獨(dú)立知識(shí)產(chǎn)權(quán)的EJB服務(wù)器?
很多JAVA程序員對(duì)袁紅崗極其佩服,,源于他做了很多人不敢想更不敢做的事情,這就是他打造了國(guó)產(chǎn)的EJB服務(wù)器,,很快,,金蝶將在國(guó)內(nèi)推出自主產(chǎn)權(quán)EJB服務(wù)器的3.0版本。?
同時(shí),,袁紅崗還是在Windows平臺(tái)上開(kāi)發(fā)企業(yè)應(yīng)用軟件的最早的一批程序員,,當(dāng)時(shí)寫(xiě)出的適合小型企業(yè)使用的財(cái)務(wù)購(gòu)銷(xiāo)存一體化軟件KINGDEE 2.7,令I(lǐng)T行業(yè)對(duì)金蝶刮目相看,,使金蝶一舉成名,,正是這些人才奠定了中國(guó)的管理軟件的基礎(chǔ)。?
袁紅崗將自己多年的經(jīng)驗(yàn)以一種樸實(shí)的風(fēng)格寫(xiě)出來(lái),,這些帖子在網(wǎng)上也影響深遠(yuǎn),。”?
更多相關(guān)資訊請(qǐng)瀏覽袁紅崗視點(diǎn)專(zhuān)區(qū):http://www.apusic.com/market/javaclub/yuan/