加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

从ADF Faces JSF 1.2中的托管bean构造函数导航

发布时间:2021-01-19 05:52:53 所属栏目:站长百科 来源:网络整理
导读:是否可以从托管bean的构造函数导航到另一个页面/视图?如果发生任何异常,我想要这个重定向.我尝试了很多方法: 尝试-1: getFacesContext().responseComplete();getFacesContext().getApplication().getNavigationHandler().handleNavigation(getFacesContex

是否可以从托管bean的构造函数导航到另一个页面/视图?如果发生任何异常,我想要这个重定向.我尝试了很多方法:

尝试-1:

getFacesContext().responseComplete();
getFacesContext().getApplication().getNavigationHandler().handleNavigation(getFacesContext(),null,"gotoPartError");    
getFacesContext().renderResponse();

尝试-2:

getServletResponse().sendRedirect("partError.jspx")

尝试-3:

getFacesContext().responseComplete();    
getFacesContext().getExternalContext().redirect(getServletRequest().getContextPath() + "/pages/partError.jspx");

尝试-4:

RequestDispatcher dispatcher = getServletRequest().getRequestDispatcher("partError.jspx");
dispatcher.forward(getServletRequest(),getServletResponse());

尝试-5:

FacesContext context = getFacesContext();
UIViewRoot newPage = context.getApplication().getViewHandler().createView(context,"/partError.jspx");
context.setViewRoot(newPage);
context.renderResponse();

尝试-6:

ControllerContext.getInstance().getCurrentViewPort().setViewId("partError");

尝试-7:

Exception Handler in adfc-config.xml

尝试-8:

Custom service handler defined in /.adf/META-INF/services/oracle.adf.view.rich.context.Exceptionhandler which extends oracle.adf.view.rich.context.Exceptionhandler

尝试-9:

By extending JSF Life Cycle

他们都没有工作.对于我收到的所有案件

java.lang.IllegalStateException: Cannot forward after response has been committed

在JSF 1.2中真的不可能吗?当我使用ADF 11.1.1.6.0(使用JSF 1.2)时,上面的一些“Try”包含ADF Faces方法.

无论如何,我需要,可以是JSF 1.2或ADF Faces,导航到错误页面.我获得成功的唯一方法是使用从后端执行的javascript,以便在出现错误时在_self窗口中打开错误页面,但我真的不喜欢它.

这件事中的任何指针都会非常有用.

解决方法

如果理解问题的原因,则更容易解决问题.一个很好的例外基本上已经说明了问题原因的一切.

仔细看看:

java.lang.IllegalStateException: Cannot forward after response has been committed

响应已经提交.这是一个不归路.也许您无法理解提交响应意味着什么(其结果是您也无法理解异常本身).

默认情况下,HTTP响应被写入缓冲区,每隔~2KB刷新一次,具体取决于服务器配置.刷新响应缓冲区会导致写入的字节实际从服务器发送到客户端.一旦第一次发生这种情况,就会认为响应已提交.这是一个不归路.如果服务器实际上需要在之后更改响应,则服务器无法从客户端返回已写入的字节.

如果您有一些可能需要更改响应的代码,那么您应该在提交响应之前调用它.

在您的特定情况下,在生成HTML输出期间,托管bean显然是在JSF呈现响应阶段中构建的.已生成的HTML输出的一部分已发送到客户端(因此,响应已提交).您显然在JSF页面中相对较晚地引用了请求范围的bean,或者响应缓冲区相对较小,或者HTML< head>相对较大,这导致在< body>之前已经冲洗.开始,等等.

您确实需要在呈现响应阶段之前调用代码.在JSF 1.2中,您可以使用< f:view beforePhase>为了这.

例如.

<f:view beforePhase="#{bean.navigate}">

public void navigate(PhaseEvent event) {
    if (event.getPhaseId() == PhaseId.RENDER_RESPONSE) {
        // Do here your job which should run right before the RENDER_RESPONSE.
    }
}

那么你的Try-1和Try-3就可以了(你可以将那些responseComplete()和renderResponse()行留下来,它们已经被隐含地处理了).

Try-2和Try-4很差.你应该避免在你的支持bean中使用javax.servlet.* import. Try-5很笨拙. Try-6,Try-7和Try-8超出了我的范围. Try-9是可行的,但非常笨拙.

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读