與微軟Visual Studio.NET程序開發有可視化工具的支持相比,人們在開發基於Java的Web用戶界面時仍然需要手工書寫大量的標簽,同時還要考慮頁面狀態信息的保存、客戶端事件處理等問題,開發難度比較大,效率較低,重用性差。Java Server Faces(JSF)技術正是為了解決這一問題應運而生的,其最引人注目的特性之一是它與標記語言、協議、客戶端設備無關。利用JSF提供的可重用、可擴展、基於組件的用戶界面框架,在快速開發工具RAD的支持下實現可視化開發。現在JSF技術已經得到了許多大廠商的支持,如Sun公司的JSF Web UI、IBM公司的JSF extension以及Oracle的ADF Faces等,許多開源項目也提供對JSF技術的支持。同時Oracle、Sun、Borland和IBM等公司都為JSF提供了開發環境。
傳統JSP開發存在的問題
實現表示層和業務層的分離,這是J2EE Web應用一直以來的理想,可惜JSP並沒有真正實現這個目標。JSP是一個基於Java的Web用戶界面開發標准技術,是一種“腳本式”開發的Web技術,在JSP頁面中混淆了大量用於顯示邏輯的HTML和用於業務邏輯的Java代碼,使得頁面設計與程序開發無法分離;JSP另一個更大的缺陷是腳本不能重用,這常常導致開發者不得不在JSP頁面之間進行復制-粘貼操作,進而導致同一段代碼出現多個版本,從而使得程序的調試和設計極其錯綜復雜。而標簽庫TagLib作為JSP的補充,將Java代碼從JSP中剝離,也只是有限地實現了表現與邏輯的分離,始終沒有擺脫代碼和HTML頁面揉和的問題。此外,JSP還存在著其他固有的缺陷,例如對應Servlet編譯的出錯信息很難在JSP中找到准確的出錯位置,由此給調試帶來很大困難。
JSF技術介紹
在Sun公司提出的J2EE平台上,Java Server Faces(JSF)是一種用於構建Web應用程序的新標准Java框架。它提供了一種以組件為中心來開發JavaWeb用戶界面的方法,從而簡化了開發。“企業開發人員”和Web設計人員將發現JSF開發可以簡單到只需將用戶界面(UI)組件拖放到頁面上,而“系統開發人員”將發現豐富而強健的JSF API為他們提供了無與倫比的功能和編程靈活性。
JSF還通過將良好構建的模型—視圖—控制器(MVC)設計模式集成到它的體系結構中,確保了應用程序具有更高的可維護性。
JSF是由Java Community Process(JCP)制定的一個Web應用框架標准。JSF具有良好定義的請求處理生命周期和豐富的組件層次結構,旨在推動基於Java的Web用戶界面開發的簡易性。利用JSF提供的可重用、可擴展、基於組件的用戶界面框架,在快速開發工具RAD的支持下,可以通過拖放組件的方式對Web用戶界面進行可視化編輯,將用戶界面上的組件與一個數據源綁定,並將客戶端用戶界面產生的事件交給服務器端處理,從而大大降低基於Java的Web用戶界面的開發難度,提高開發效率。
簡而言之,JSF的主要部分是一個GUI組件框架和一個用於跨不同標記語言或客戶端設備描述組件的靈活模型。JSF GUI組件框架使開發人員能夠創建JSF應用程序的用戶界面。
JSF GUI組件包括標准的HTML表單控件(如按鈕)、布局組件,以及更復雜的組件,如數據表。此外,第三方還可以擴展規范中定義的基本類,來開發額外的GUI組件。
JSF組件的體系結構是這樣設計的:組件的功能由組件類定義,組件的呈現由一個單獨的呈現器定義。呈現器定義了組件類如何映射為適合特定客戶的組件標簽。
JSF的主要優勢之一就是它既是Java Web用戶界面標准又是嚴格遵循模型-視圖-控制器(MVC)設計模式的框架。用戶界面代碼(視圖)與應用程序數據和邏輯(模型)的清晰分離使JSF應用程序更易於管理。為了准備提供頁面對應用程序數據訪問的JSF上下文和防止對頁面未授權或不正確的訪問,所有與應用程序的用戶交互均由一個前端控制器來處理。JSF技術做到了應用程序邏輯和表示的完全分離,是真正徹底的MVC模式。
JSF技術現在的版本是1.1,下一個版本將是1.2,它將和J2EE 5.0一起發布。
開發基於JSF的Web應用程序步驟
JSF是構建Web應用程序的新標准Java框架,可以依據JSF的框架標准手工書寫Web應用程序,以文本方式像寫HTML或JSP程序一樣實現Web用戶界面的設計;同時在開發、運行以及調試前還需要搭建系統運行平台。這樣做的缺點是不能充分體現可視化開發的便捷和高效,一般是在分析Web應用程序的結構時使用。
使用快速開發工具RAD,是實現JSF可視化開發的先決條件。在快速開發工具的支持下,符合JSF標准的Web應用程序開發、運行以及調試均在IDE環境中實現,大大提高了開發的效率,整個程序開發過程快捷高效。現在獲得大廠支持的RAD工具很多,比如IBM公司的WebSphere Studio,Oracle公司的JDeveloper,和Sun公司的Java Studio Creator等都提供對JSF開發的支持。
如果不使用IDE開發環境,那麼在開發應用程序前,必須先搭建系統運行平台。比如安裝TOMCAT和Sun的JavaWeb Services Developer Pack (JWSDP) 1.2。使用JSF時需要JSTL與JSF的標簽函數庫,在Web應用程序的WEB-INF/lib目錄下放入所需的JAR文件。如果使用IDE開發環境,開發前期的准備工作比較簡單,只需安裝好IDE環境即可,不需要其他的配置,一般IDE中都有內嵌的應用服務器,足以支持程序的開發、運行和調試。不管是否使用IDE開發環境,JSF開發Web應用程序通常分為以下三個步驟:
視圖設計
方便、快捷地開發基於JSF的Web應用程序,是在JSF提供了一組豐富的、可重用的服務器端用戶界面組件的條件下實現的。在開發工具的支持下,用戶可以很容易地在可視化環境中利用這些組件構建Web用戶界面,處理組件的數據校驗、事件處理等用戶界面管理問題。
設計每個需要的JSP頁面,在頁面中放置JSF的內置組件,並將組件與應用層的JavaBean綁定。利用RAD工具能通過拖放組件的方式輕松實現頁面文件,不需要手寫大量代碼。開發工具自動生成頁面對應的Java文件,在文件中定義好了頁面的JSF組件及其getter、setter方法以及JSF組件的“action”屬性對應的方法等。程序員可以方便地在已有程序的基礎上修改、調試。
模型設計
JSF技術做到了應用程序邏輯和表示的完全分離。在模型設計部分,程序員只需要考慮程序的邏輯功能,不需要考慮數據的表現形式。JSF的模型是通過JavaBean程序來實現的。
控制器設計
JSF的控制器設計是在配置文件中完成的,相關的主要有兩個文件:web.xml文件和faces-config.xml文件(均在WEB-INF目錄下)。web.xml文件主要用於控制JSF的生命周期,實現部署描述符。faces-config.xml文件實現導航,在文件中控制頁面之間的跳轉流程。
配置步驟是首先配置Web應用程序的web.xml文件,然後是配置JSF的控制文件faces-config.xml文件。這兩個文件格式固定,在IDE環境中這個過程由工具自動完成,不需要設計人員的干預,即使手工配置也比較簡單。
JSF的技術重點在View部分,它實現了Web應用程序設計角色的完全分離。JSF網頁設計者只需要專注於頁面的設計;應用程序開發者主要關心Model部分的JavaBean的開發;程序的流程控制則由faces-config.xml專門配置。
JSF是基於Java的Web應用開發領域裡提供了一個可重用、可擴展、基於組件、工具友好的服務器端UI框架。在支持JSF的RAD開發工具中,人們可以像使用VisualStudio.NET一樣方便快捷地構建Web用戶界面,大大降低了利用Java技術實現Web用戶界面的難度,提高了開發效率。
JSF具有強大的組件體系和事件處理系統,完全實現了MVC模式的應用架構,使得基於Java的Web用戶界面程序開發難度大大降低,提高了開發效率,非常適用於Web頁面的開發。
JSF是一個開放的標准,具有很好的可擴展性。依照JSF的規范,用戶完全可以根據需求定制自己的用戶界面組件、事件處理器、數據校驗和轉換組件等,這些組件和標准的JSF組件一樣是可重用的。JSF API是直接架構在Servlet API之上的,因此JSF用戶界面組件的呈現並不局限於特定的腳本技術或標記語言。表示層完全可以采用JSP之外的技術。在眾多的J2EE表現層框架技術中,JSF表現出其旺盛的生命力。盡管JSF技術還有不少問題,但隨著JSF技術的不斷成熟和版本更新,其必將獲得越來越多的應用。