Мой пример использования следующий: пользователю была показана страница JSF2.Страница содержит кнопку с поддержкой Ajax:
<p:commandButton value="#{msgs.reset}" process="@this"
actionListener="#{reworkSearchMB.clearReworkSearch()}" tabindex="13"
update="mainpanel messages" global="false"
disabled="#{!userMB.hasAccessToViewRework() and !userMB.hasAccessToCreateOrUpdateRework()}"
/>
Таким образом, пользователь ждет ДЛИТЕЛЬНОГО времени, пока страница находится на экране и сеанс истекает.После этого пользователь нажимает кнопку с поддержкой Ajax.
Я хочу, чтобы это произошло: перенаправьте пользователя на экран входа в систему.
Итак, следуя совету Джима Дрисколла из http://weblogs.java.net/blog/2009/05/14/redirecting-jsf-20-ajax-request, Я создал PhaseListener, подключенный к фазе RESTORE_VIEW, который проверяет, истек ли сеанс, и, если это так, перенаправляет на страницу входа:
ExternalContext ectx = ctx.getExternalContext();
String newUrl =
ectx.encodeActionURL(ctx.getApplication().getViewHandler().getActionURL(ctx,
"/login.xhtml"));
try {
ectx.redirect(newUrl); // calls responseComplete() according to JavaDocs
} catch (IOException ex) {
throw new FacesException(ex);
}
При прослушивании beforePhase (RESTORE_VIEW) я получаю исключение NullPointerException:
SEVERE: java.lang.NullPointerException
at com.sun.faces.context.PartialViewContextImpl.createPartialResponseWriter(PartialViewContextImpl.java:434) ~[jsf-impl.jar:2.1.0-FCS]
at com.sun.faces.context.PartialViewContextImpl.access$300(PartialViewContextImpl.java:71) ~[jsf-impl.jar:2.1.0-FCS]
at com.sun.faces.context.PartialViewContextImpl$DelayedInitPartialResponseWriter.getWrapped(PartialViewContextImpl.java:575) ~[jsf-impl.jar:2.1.0-FCS]
at javax.faces.context.PartialResponseWriter.startDocument(PartialResponseWriter.java:115) ~[jsf-api.jar:2.1.0-FCS]
at org.primefaces.context.PrimePartialResponseWriter.startDocument(PrimePartialResponseWriter.java:103) ~[primefaces-2.2.1.jar:na]
at com.sun.faces.context.ExternalContextImpl.redirect(ExternalContextImpl.java:572) ~[jsf-impl.jar:2.1.0-FCS]
at com.argushealth.rework.phaselistener.SecurityPhaseListener.doRedirect(SecurityPhaseListener.java:80) ~[SecurityPhaseListener.class:na]
at com.argushealth.rework.phaselistener.SecurityPhaseListener.beforePhase(SecurityPhaseListener.java:42) ~[SecurityPhaseListener.class:na]
at com.sun.faces.lifecycle.Phase.handleBeforePhase(Phase.java:228) ~[jsf-impl.jar:2.1.0-FCS]
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:99) ~[jsf-impl.jar:2.1.0-FCS]
at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:113) [jsf-impl.jar:2.1.0-FCS]
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118) [jsf-impl.jar:2.1.0-FCS]
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:409) [jsf-api.jar:2.1.0-FCS]
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1534) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.doInvoke(ApplicationDispatcher.java:787) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:649) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:483) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.doDispatch(ApplicationDispatcher.java:454) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.dispatch(ApplicationDispatcher.java:350) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:300) [web-core.jar:3.1]
at com.argushealth.enterprise.security.web.spring.exception.AbstractExceptionHandler.handleException(AbstractExceptionHandler.java:44) [enterprise-security-web-spring-1.0.4.jar:na]
at com.argushealth.enterprise.security.web.spring.ui.ExceptionHandlingFilter.doFilterHttp(ExceptionHandlingFilter.java:57) [enterprise-security-web-spring-1.0.4.jar:na]
at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) [spring-security-core-2.0.3.jar:2.0.3]
at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:371) [spring-security-core-2.0.3.jar:2.0.3]
at org.springframework.security.util.FilterChainProxy.doFilter(FilterChainProxy.java:174) [spring-security-core-2.0.3.jar:2.0.3]
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:236) [spring-2.5.5.jar:2.5.5]
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167) [spring-2.5.5.jar:2.5.5]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256) [web-core.jar:3.1]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:215) [web-core.jar:3.1]
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:279) [web-core.jar:3.1]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) [web-core.jar:3.1]
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655) [web-core.jar:3.1]
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595) [web-core.jar:3.1]
at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:98) [web-glue.jar:3.1]
at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:91) [web-glue.jar:3.1]
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:162) [web-core.jar:3.1]
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:326) [web-core.jar:3.1]
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:227) [web-core.jar:3.1]
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:170) [kernel.jar:3.1]
at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:822) [grizzly-http.jar:1.9.31]
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:719) [grizzly-http.jar:1.9.31]
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1013) [grizzly-http.jar:1.9.31]
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:225) [grizzly-http.jar:1.9.31]
at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79) [grizzly-http.jar:1.9.31]
at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.ContextTask.run(ContextTask.java:71) [grizzly-framework.jar:1.9.31]
at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) [grizzly-utils.jar:1.9.31]
at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) [grizzly-utils.jar:1.9.31]
at java.lang.Thread.run(Thread.java:619) [na:1.6.0_20]
Спасибо, Мигель Пинг, это очень полезно.Я прочитал предоставленную вами статью и постараюсь исправить эту ошибку.Но я сталкиваюсь с другой проблемой, когда пишу код ниже:
// workaround for PrimeFaces
new RequestContextImpl(ec);
if (ec.getRequestParameterMap().containsKey(Constants.PARTIAL_PROCESS_PARAM)
&& !ec.getRequestParameterMap().get(Constants.PARTIAL_PROCESS_PARAM).equals("@all")) {
fc.setViewRoot(new PartialViewRoot(new UIViewRoot()));
}
Произошла ошибка компиляции, потому что я не могу найти Class RequestContextImpl и PartialViewRoot в моемфайл jar простых лиц.Я использую Primefaces-2.2.1.Я обнаружил, что эти два класса существуют в некоторых предыдущих версиях, но не в 2.2.x.И я копирую два класса из версии 2.0.0 в свой собственный проект, но он все еще не работает.Есть идеи?