3.4 请求处理生命周期阶段
JSF定义了标准的请求处理生命周期阶段。应用程序开发人员并不需要知道生命周期的详细信息,但在某些情况下我们可以从中得到帮助,比如何时验证,何时转换,通常在何时处理事件,怎样改变事件的处理方式和时间。
一个JSF页面是由被称为视图的UI组件树来表示的。当客户端向该页面发起请求时,开始一个生命周期。在生命周期中,JSF的实现必须建立视图,同时考虑保存此前提交页面的状态。当客户端提交页面时,JSF的实现必须执行一些任务,比如验证视图中组件的数据输入,将输入数据转换为服务器端指定的类型,并且将数据绑定到backing bean。JSF的实现为生命周期中的一系列步骤执行所有这些任务。
应用程序的不同组件经历以下明确定义的请求处理生命周期阶段。
3.4.1 恢复视图
恢复并创建一个服务器端的组件树表示来自客户端的UI信息。
如果是第一次向一个URL发起请求,那么创建一个新的视图对象并呈现给客户端。这个视图同时存储在当前FacesContext实例中。如果已经在FacesContext中发现视图状态,那么视图被恢复并显示。
任何与UI组件连接的自定义的转换器、验证器和渲染器,在这个阶段被恢复。如果UI组件的值被直接映射到一个托管Bean定义的属性,那么该属性的值将被恢复并与视图相关联。大部分的工作是由ViewHandler.restoreView方法来处理的。
3.4.2 接受请求值
这个阶段将使用来自客户端的请求参数、请求头信息、Cookie等更新服务器端组件。
更具体地说,UIComponent.processDecodes方法被所有组件调用。这一阶段可能结束于处理验证阶段或渲染响应阶段。如果任何转换或验证失败,则终止当前操作,控制直接转到渲染响应阶段,展示转换或验证的错误给客户端。
3.4.3 处理验证
这一阶段将处理所有UIComponent已配置的验证和数据类型转换。
在这个阶段中,UIComponent.processValidators方法被所有组件调用。如果有任何转换或验证错误发生,那么当前进程被终止,并且控制被引导到渲染响应阶段报告发生的任何错误。
3.4.4 更新模型值
到达这个阶段意味着请求值的语法是有效的。
UIComponent的值会与模型对象同步,模型对象通常是backing bean。在这个阶段中,UIComponent.processUpdates方法被所有组件调用。将请求值赋值给模型对象,也可能会导致排队和触发事件。
3.4.5 调用应用
调用应用的逻辑并执行导航处理。
所有已注册的UIComponent的监听器被调用。例如,所有的动作组件(如命令按钮或超链接)有默认的动作监听器,会在这个阶段被调用。
3.4.6 渲染响应
渲染响应并将其返回给客户端应用程序。
在渲染响应之前,应用程序通过调用UIViewRoot.saveState方法在缓存中存储视图的状态。