對(duì)于jsf規(guī)范,個(gè)人覺(jué)得和其他框架相比,最大的區(qū)別,可能在于jsf劃分了web 請(qǐng)求的生命周期。like ejb一樣,web 請(qǐng)求也是有生命周期的。雖然,在其他的框架中,也可以看到相關(guān)的生命周期,但還是沒(méi)有jsf劃分的清晰。也許,這也是jsf的一大特色。
對(duì)于生命周期的執(zhí)行,所有的操作都?xì)w結(jié)到Lifecycle這個(gè)接口。接口包括了兩個(gè)主要的方法:
public abstract void execute(FacesContext context) throws FacesException;和
public abstract void render(FacesContext context) throws FacesException;
前者是用來(lái)執(zhí)行各個(gè)生命周期的階段,也就是除了render之外的其他五個(gè)階段,而且是按照相應(yīng)的順序執(zhí)行。而render,是執(zhí)行最后一個(gè)階段,展示頁(yè)面。可能有人不太理解,為什么不把兩個(gè)方法合并成一個(gè)方法,剛開(kāi)始,我也是這么認(rèn)為。既然已經(jīng)定義了相應(yīng)的Phase,何必要把最后的render過(guò)程分離出來(lái)。看了sun 的RI實(shí)現(xiàn)類(lèi),發(fā)現(xiàn)在render之前需要進(jìn)行context.getResponseComplete()判斷,可能規(guī)范中,認(rèn)為render是必須要執(zhí)行的階段,其他的階段可以跳過(guò),所以分離了相應(yīng)的方法,同時(shí)在執(zhí)行前,為了避免重復(fù)輸出,需要對(duì)render過(guò)程進(jìn)行特殊的處理.
規(guī)范中定義了6個(gè)階段,從下面的流程圖中可以看到。
簡(jiǎn)單介紹一下每個(gè)階段的工作:
RESTORE_VIEW:查找原有的view ,恢復(fù)原有的狀態(tài),如果沒(méi)有,則調(diào)用ViewHandler.createView,如果為post操作,則按照順序執(zhí)行各個(gè)階段。
否則執(zhí)行RENDER_RESPONSE階段。
APPLY_REQUEST_VALUES:讀取客戶(hù)端參數(shù),處理各個(gè)組件的processDecodes方法,內(nèi)部調(diào)用decode方法,由Renderer執(zhí)行decode方法
PROCESS_VALIDATIONS:執(zhí)行組件的processValidators方法,對(duì)于UIInput執(zhí)行validate方法,用于綁定值,調(diào)用convert,和validate
UPDATE_MODEL_VALUES:執(zhí)行組件的processUpdates方法,對(duì)于UIViewRoot,執(zhí)行broadcastEvents和notifyPhaseListeners
所有的UIInput,執(zhí)行updateModel方法。
INVOKE_APPLICATION:調(diào)用UIViewRoot.processApplication方法。這一過(guò)程主要讀取相應(yīng)的action配置,如果存在action,則調(diào)用action,也就是調(diào)用應(yīng)用邏輯。在執(zhí)行完相應(yīng)的邏輯后,查詢(xún)action是否返回值,如果有,由navigationHandler去讀取下一個(gè)view id。
RENDER_RESPONSE:展示view,調(diào)用ViewHandler.renderView,展示view。
每個(gè)階段定義定義的都比較清晰,有一點(diǎn)需要注意的是,在處理請(qǐng)求時(shí),并不一定會(huì)執(zhí)行每個(gè)階段,可能其中會(huì)直接跳到最后的render response階段。舉例來(lái)說(shuō),如果validator時(shí),存在錯(cuò)誤信息,那么就會(huì)直接到render response階段,而下一個(gè)階段不會(huì)執(zhí)行。