странное поведение перенаправления jsf - PullRequest
2 голосов
/ 03 октября 2010

Я пытаюсь перейти на другую страницу с перенаправлением, назначив правило навигации.Веб-страница, на которую я пытаюсь перенаправить, работает нормально, когда она вызывается напрямую.

Когда я устанавливаю направление на страницу jsp, которая просто включает в себя сообщение <jsp:forward page="faces/another.xhtml" />, я получаю следующее исключение nullpointerexception, и перенаправление завершается неудачно:

java.lang.NullPointerException
    at org.icefaces.util.EnvUtils.isICEfacesView(EnvUtils.java:69)
    at org.icefaces.event.BridgeSetup.processEvent(BridgeSetup.java:66)
    at javax.faces.event.SystemEvent.processListener(SystemEvent.java:102)
    at com.sun.faces.application.ApplicationImpl.processListeners(ApplicationImpl.java:1993)
    at com.sun.faces.application.ApplicationImpl.invokeListenersFor(ApplicationImpl.java:1969)
    at com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:299)
    at com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:243)
    at com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:114)
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
    at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:313)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
    at java.lang.Thread.run(Unknown Source)
03.Eki.2010 02:07:58 org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet Faces Servlet threw exception
java.lang.NullPointerException
    at javax.faces.component.UIViewRoot.getViewMap(UIViewRoot.java:1523)
    at javax.faces.component.UIViewRoot.getViewMap(UIViewRoot.java:1487)
    at org.icefaces.util.EnvUtils.isICEfacesView(EnvUtils.java:70)
    at org.icefaces.context.DOMPartialViewContext.getPartialResponseWriter(DOMPartialViewContext.java:97)
    at org.icefaces.context.DOMPartialViewContext.getPartialResponseWriter(DOMPartialViewContext.java:95)
    at com.sun.faces.context.AjaxExceptionHandlerImpl.handlePartialResponseError(AjaxExceptionHandlerImpl.java:190)
    at com.sun.faces.context.AjaxExceptionHandlerImpl.handle(AjaxExceptionHandlerImpl.java:119)
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:119)
    at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:313)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
    at java.lang.Thread.run(Unknown Source)

Затем я устанавливаюПравить прямо на /faces/another.xhtml.перенаправление прошло успешно, но я получаю следующее предупреждающее сообщение:

WARNING: JSF1015: Request path '/faces/another.xhtml' begins with one or more
occurrences of the FacesServlet prefix path mapping '/faces'.

Как вы думаете, как правильно настроить навигацию?Большое спасибо.

1 Ответ

3 голосов
/ 03 октября 2010

Видимо, вы уже в контексте JSF.Удалите префикс /faces из URL.

<jsp:forward page="another.xhtml" />

Обратите внимание, что вы не перенаправляете сюда, а просто перенаправляете запрос в другой источник.Перенаправление в основном предписывает клиенту запустить новый HTTP-запрос к серверу, URL которого затем отображается в адресной строке браузера.Перенаправление обычно выполняется с помощью ExternalContext#redirect() в методе действия компонента (который находится под прикрытием, вызывая HttpServletResponse#sendRedirect(), а затем FacesContext#responseComplete()),или добавив запись <redirect/> к <navigation-case> в faces-config.xml.

...