百度广告
请求处理过程总览(FacesServlet#service)
1 FacesContext context = facesContextFactory.getFacesContext(servletConfig.getServletContext(), request, response, lifecycle);
1 FacesContext ctx = new FacesContextImpl(new ExternalContextImpl((ServletContext) sc,(ServletRequest) request,(ServletResponse) response),lifecycle);
1 this.externalContext = ec;
3 this.rkFactory = (RenderKitFactory)FactoryFinder.getFactory(FactoryFinder.RENDER_KIT_FACTORY);
FacesContext创建出来以后,正如上面所说,要让他经过LifeCycle这个"Filter Chain"的逐步处理了。那么,Filter Chain里面放的是一个一个Filter,那么LifeCycle这个Chain里面放的是什么呢?答案是Phases.
1 lifecycle.execute(context);
在LifeCycleImpl这个实现中,存放了一个Phase对象的数组,存放了7个Phase.其中第一个是null,然后依次是视图重建、应用请求值、验证、更新模型值、执行应用程序、呈现响应。在execute方法中,调用了从视图重建开始到执行应用程序为止的5个Phase,而在render方法中,调用了最后一个Phase,也就是呈现响应。在LifeCycleImpl类中,代码
private Phase response = new RenderResponsePhase();
// in order by the ordinal property of each phase
null, // ANY_PHASE placeholder, not a real Phase
new ApplyRequestValuesPhase(),
new UpdateModelValuesPhase(),
response
在Servlet Filter中,可以由每一个Filter来决定是否要调用下一个Filter,从而决定是否让请求继续通过Filter Chains中的后续Filter,是链式调用的过程。而在LifeCycle的execute方法中,是用一个for循环顺序执行几个Phase.在每一个Phase执行完之后,都会检查FaceContext对象中是否设置了停止后续处理直接呈现响应的标志(renderResponse)或者已经完成了响应无需后续处理也不需要经过呈现响应阶段了(responseComplete),如果标志为true,那么就不再执行后续Phase.
1 for (int i = 1, len = phases.length -1 ; i < len; i++) { // Skip ANY_PHASE placeholder
3 if (context.getRenderResponse() ||
5 break;
7
9
在LifeCycle的render方法中,也会检查FacesContext的responseComplete状态,如果为true,那么就不再执行 render Phase.于是我们此刻知道了在我们自己所写的一些代码或者JSF库里面的一些代码中,调用FacesContext的 responseComplete方法和renderResponse得作用原理。render方法主要代码
2 response.doPhase(context, this,listeners.listIterator());
另外注意,Phase这个概念、接口,以及几个实现,都是jsf-ri项目中的,而在jsf-api中不存在Phase这个概念。所以,LifeCycle是JSF标准的内容,而通过几个Phase来处理请求这种实现是sun的参考实现的做法。
点击加载更多评论>>