在Oracle ADF開發(fā)中,一個(gè)請求發(fā)生后,經(jīng)過ADF處理后,我們可以很快得到響應(yīng)頁面,但在請求過程中ADF框架在背后究竟做了什么東西呢?今天讓我們一起來了解下,ADF、JSF是基于組件模型的,不同于請求響應(yīng),它的每個(gè)組件具有生命周期的概念,在不同的階段處理、完成不同的任務(wù),理解了這個(gè)東西對(duì)于日常開發(fā)是很有幫助的,我們會(huì)清楚地知道代碼會(huì)在哪個(gè)階段執(zhí)行,還有當(dāng)發(fā)生異常時(shí),我們可以根據(jù)異常快速定位到大概是哪些處理階段發(fā)生問題,從而有針對(duì)性地排查處理,不扯那么多了,進(jìn)入正題。
      首先給出JSF和Oracle ADF頁面請求處理的生命周期的序列圖:


大學(xué)生就業(yè)培訓(xùn),高中生培訓(xùn),在職人員轉(zhuǎn)行培訓(xùn),企業(yè)團(tuán)訓(xùn)


以下對(duì)序列圖進(jìn)行說明:
1、 一個(gè)http://yourserver/yourapp/faces/some.jsp到達(dá);
2、 ADF的過濾器ADFBindingFilter會(huì)找到當(dāng)前session的綁定容器(BindingContext),如果是用戶第一次訪問則會(huì)進(jìn)行創(chuàng)建:

  • 在BindingContext初始化中,ADF會(huì)獲取web.xml文件<context-param>的 CpxFileName值,加上.cpx后綴作為綁定上下文數(shù)據(jù)文件,默認(rèn)參數(shù)是:DataBindings;

  •  讀取DataBindings.cpx文件以發(fā)現(xiàn)數(shù)據(jù)控制定義,用于在運(yùn)行時(shí)實(shí)例化綁定容器的頁面定義文件名以及將JSP頁面與其頁面定義文件相關(guān)聯(lián)的頁面映射;

  •  構(gòu)造每個(gè)數(shù)據(jù)控件的一個(gè)實(shí)例,并引用每個(gè)BindingContainer(頁面級(jí)別),每個(gè)綁定容器的內(nèi)容在第一次被頁面使用時(shí)被懶惰地加載。

BindingContext:In Brief, Data Bindings file contains the page Map, Page Definition references , References to Data Controls.
3、 接著ADFBindingFilter在參與請求的每個(gè)數(shù)據(jù)控件上調(diào)用beginRequest()方法(不同的階段會(huì)有不同的調(diào)用方法,生命周期決定的),這樣就可以在每個(gè)請求開始時(shí)通知每個(gè)數(shù)據(jù)控件,從而可以執(zhí)行必要的設(shè)置。
4、 從AM池中獲取AM實(shí)例;
5、 在JSF的各個(gè)標(biāo)準(zhǔn)處理階段(Lifecycle類,由FacesServlet負(fù)責(zé)創(chuàng)建),除了完成自己的工作外,順便通知ADF(ADFPhaseListener類),以便ADF在不同的階段增加自己的處理內(nèi)容,畢竟ADF是繼承自JSF,肯定需要有自己特色的一些東西的,具體如圖所示:


大學(xué)生就業(yè)培訓(xùn),高中生培訓(xùn),在職人員轉(zhuǎn)行培訓(xùn),企業(yè)團(tuán)訓(xùn)


6、 ADFPhaseListener創(chuàng)建一個(gè)ADF PageLifecycle對(duì)象來處理每個(gè)請求,并將不同階段的處理委托給ADF PageLifecycle類中的相應(yīng)方法,此過程會(huì)創(chuàng)建BindingContainer對(duì)象;
7、 JSF轉(zhuǎn)發(fā)到響應(yīng)的頁面;
8、 頁面上的UI組件訪問頁面的綁定容器中的值綁定和迭代器綁定,并在瀏覽器中輸出;
9、 ADFBindingFilter在參與請求的每個(gè)數(shù)據(jù)控件上調(diào)用endRequest()方法(各司其職),這樣可以在每個(gè)請求結(jié)束時(shí)通知每個(gè)數(shù)據(jù)控件,從而可以執(zhí)行必要的資源清理工作;
10、將應(yīng)用程序模塊的實(shí)例釋放回應(yīng)用程序模塊池
11、用戶在瀏覽器看到響應(yīng)頁面。