您好,登錄后才能下訂單哦!
本篇內容主要講解“JSF的工作方式是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“JSF的工作方式是什么”吧!
1.JSF的工作方式
JSF應用是通過處理由頁面中組件觸發的事件來工作的。這些事件是由用戶的動作引起的。比如,當用戶單擊一個按鈕時,按鈕會觸發一個事件,通過編寫監聽這個事件的監聽器,JSF開發人員可以決定當特定事件發生時JSF應用應該做什么。也就是說,JSF應用是事件驅動的。圖1說明了JSF應用的處理過程。
圖1 JSF應用是事件驅動的
當一個事件發生時(比如,用戶單擊了一個按鈕),事件通知通過HTTP發往服務器。服務器端使用叫作FacesServlet的特殊servlet處理該通知。Web容器里的每個JSF應用都有它自己的FacesServlet。
在后臺,每個JSF請求都觸發3件事情,如圖2 JSF的工作方式。
圖2 JSF的工作方式
為了處理JSF請求,它們必須交由FacesServlet處理,指定這種重定向是通過部署描述符中的servlet和servlet-mapping標記來實現的。
<!-- Faces Servlet -->
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<!-- Faces Servlet Mapping -->
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
</servlet-mapping>
這表示所有請求的URL中都必須包含/faces/這個字符串模式,servlet-mapping元素下的url-pattern元素指定了這一點。注意:
可以指定一個上下文參數saveStateInClient并賦給它一個true值,以此來強制JSF把狀態存放在客戶端而不是服務器端。如果您打算這么做,必須在部署描述符中的servlet元素之前加入如下的context-param元素。
<context-param>
<param-name>saveStateInClient</param-name>
<param-value>false</param-value>
</context-param>
FacesServlet生成一個叫作FacesContext的對象,它包含了處理請求所必須的信息。更確切地說,FacesContext對象中包含Web容器傳給FacesServlet的services方法的 ServletContext、ServletRequest及ServletResponse對象。在處理過程中,主要修改的就是這個 FacesContext對象。接著就是處理,處理器是一個叫作Lifecycle的對象。FacesServlet把控制權轉交給Lifecycle,Lifecycle對象分6個階段來處理FacesContext對象,我們稍后將會看到這些階段。注意:
Lifecycle對象處理JSP請求所需的一系列動作稱為請求處理生命周期(request processing lifecycle),這個詞自始至終貫穿本書。
JSF的工作方式允許使用一個應用配置文件來配置JSF應用。討論過Lifecycle對象的處理階段后,我們會討論如何使用這個配置文件來注冊JavaBeans。
2.理解請求處理生命周期的各個階段
Lifecycle對象分6個階段來處理JSF請求(被封裝在FacesContext對象里,而FacesContext對象就是處理過程中由Lifecycle讀取并修改的對象),過程如下:
◆重建組件樹 JSF應用里的JSP頁面被表示成一個組件樹。在這個階段,通過重建這棵樹來開始Lifecycle的處理過程。每個組件樹都有一個在整個應用范圍里惟一的標識符,此標識符是所請求URI的路徑信息部分。比如,對于一個URI為/faces/index.jsp的請求,組件樹的標識符就是 /index.jsp。生成的組件樹保存在FacesContext對象中,以備后面的處理過程所用。
◆應用請求值 在這個階段,使用請求里的當前值來更新每個組件的本地值。這些值可能來自請求參數、請求的報頭及cookie等。在這個階段的處理中,組件可以往事件隊列里加入某些事件,這些事件可在隨后的處理階段處理。
◆處理驗證 當每個組件的本地值被更新后,在此階段中,Lifecycle對象會驗證這些值的合法性。要求驗證的組件必須提供驗證邏輯的實現。作為選擇,開發人員可以為一個組件注冊零個或多個驗證器。如果發現外部驗證器,那么還會應用這些外部驗證器里的驗證邏輯來驗證本地值。
◆更新模型值 只有當組件樹中所有組件的本地值都通過驗證后,才有可能到達該階段。在這個階段里,LifeCycle更新應用的模型數據。組件在這個階段也可以排列事件。
◆調用應用 在這個階段,JSF實現處理所有應用層次的事件,比如提交表單或鏈接到其他頁面等。
◆呈現響應 在這個階段,JSF實現將響應發回客戶端。
由于請求處理生命周期里的應用請求值、處理驗證、更新模型值和調用應用等階段都可以在當前請求對應的FacesConetxt的實例里排列事件,因此,JSF實現必須在這些階段后處理這些事件。
在兩個階段中間,Lifecycle對象會檢查所有需要調用的事件監聽器。當編寫事件監聽器時,需要選擇事件監聽器應在哪個階段過后調用。或者,也可以編寫一個在不同階段后調用的事件監聽器。圖3表明了處理JSF請求的各個階段。標有“處理事件”的方框表示Lifecycle對象在該處執行事件監聽器。
圖3 請求處理生命周期的各個階段
注意,事件監聽器可能會改變處理過程。它可以指示Lifecycle對象直接跳到***一個階段,或是在當前事件處理完后馬上退出。
3.使用應用配置文件注冊JavaBeans
可以通過一個應用配置文件很容易地配置JSF應用。在這個文件里,可以注冊應用中用到的JavaBeans,通過指定頁面導航規則定義程序控制流程,注冊自定義組件及執行其他配置工作等。
應用配置文件是一個XML文件,可以有好幾種聲明方式。最簡單的方式是把它放到WEB-INF目錄中,并且命名為faces-config.xml。應用配置文件的根元素是faces-config。下面是應用配置文件的框架:
<?xml version="1.0"?>
<!DOCTYPE faces-config PUBLIC
"-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.0//EN"
"http://java.sun.com/dtd/web-facesconfig_1_0.dtd">
<faces-config>
</faces-config>
JSF應用的許多方面都可以通過應用配置文件來配置。在這里,我們主要關注如何注冊JavaBeans(用于本章稍后的例子)。第15章會詳細講解應用配置文件。在一個JSP頁面里,可以使用jsp:useBean動作告訴JSP容器,正在使用jsp:useBean動作的class特性里指定的JavaBean,如下所示:
<jsp:useBean id="numberBean" class="ch02.NumberBean" scope="session"/>
這將告訴Web容器裝入JavaBean類并且在JSP頁面被調用時創建一個實例。jsp:useBean動作只需要在一個頁面里聲明,而在同一個應用的所有JSP頁面里可用。在JSF應用中允許您做到這一點,而不是在應用配置文件中注冊JavaBean。
使用<jsp:useBean>有一個缺點,如果一個頁面在包含jsp:useBean動作的頁面之前被調用,Web容器會拋出一個異常。這是因為這個頁面試圖使用一個尚未創建的JavaBean。而使用應用配置文件注冊該JavaBean就不會有這個問題。
對于每個打算在應用配置文件里注冊的JavaBean,使用faces-config元素中的managed-bean標記,在managed-bean元素中有下列子元素:
◆managed-bean-name 標記定義從JSP頁面里引用JavaBean時使用的名稱。
◆managed-bean-class元素 指明JavaBean類。
◆managed-bean-scope元素 定義JavaBean的作用域。
下面是managed-bean的一個例子:
<managed-bean>
<managed-bean-name>myBean</managed-bean-name>
<managed-bean-class>myPackage.MyBean</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
</managed-bean>
本例中的managed-bean元素定義了一個類型為myPackage.MyBean的JavaBean,在JSF應用的JSP頁面里可以用名稱myBean來引用它,它的作用域是session,表示開始一個用戶會話時就創建這個bean的一個實例。
到此,相信大家對“JSF的工作方式是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。