2016-07-26 2 views
1

두 개의 JSF 기반 WAR 프로젝트가 하나의 EAR 아카이브에 있고, 두 프로젝트 모두 종속성으로 OmniFaces가 있으며 둘 다 배치됩니다. . 하나의 전쟁에서 OmniFaces 제거 작업 벌금을 배포하는 경우java.lang.NullPointerException org.omnifaces.cdi.eager.EagerBeansPhaseListener.afterPhase 하나의 EAR에 WAR 2 개가있는 경우

java.lang.NullPointerException 
    at org.omnifaces.cdi.eager.EagerBeansPhaseListener.afterPhase(EagerBeansPhaseListener.java:50) 
    at com.sun.faces.lifecycle.Phase.handleAfterPhase(Phase.java:189) 
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:107) 
    at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:121) 
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198) 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646) 
    at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:344) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:214) 
    at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:78) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:214) 
    at org.glassfish.tyrus.servlet.TyrusServletFilter.doFilter(TyrusServletFilter.java:298) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:214) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:316) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160) 
    at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734) 
    at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673) 
    at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174) 
    at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:415) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:282) 
    at com.sun.enterprise.v3.services.impl.ContainerMapper$HttpHandlerCallable.call(ContainerMapper.java:459) 
    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167) 
    at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:206) 
    at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:180) 
    at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235) 
    at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119) 
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:283) 
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:200) 
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:132) 
    at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:111) 
    at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77) 
    at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:536) 
    at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112) 
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117) 
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:56) 
    at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137) 
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:565) 
    at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:545) 
    at java.lang.Thread.run(Thread.java:745) 

: 배포이 오류가 발생 .

Omnifaces 2.3 PrimeFaces 5.3 Payara 4.1.152

답변

0

CDI 본 명세서에서 unclarity 의해 발생하는 알려진 문제이다. 참조 :

내가 @Eager 다중 모듈 EAR에서 테스트되지 않았 음을 인정해야합니다. 이 NullPointerException은 불행한 일이며 웹 응용 프로그램을 이런 식으로 사용할 수 없도록 만드는 것이 결코 아닙니다. 기껏해야 OmniFaces CDI 관련 기능 만 사용할 수 없지만 나머지는 계속 작동해야합니다.

여기에 issue 290을 작성했으며 issue 281에 따라 현재 사용 가능한 서버에 대해 다중 모듈 EAR의 모든 CDI 기능을 다시 테스트 할 것입니다.

가장 좋은 방법은 OmniFaces JAR을 편집하고 /META-INF/faces-config.xml에서 EagerBeansPhaseListener을 제거하는 것입니다. 뷰 범위가 지정된 bean에 대한 @Eager 기능 만 작동을 멈 춥니 다.


업데이트issue 290에 따라 나는이 NPE를 해결했습니다. 오늘은 2.5-SNAPSHOT에서 사용할 수 있습니다.

+0

FullAjaxExceptionHandler 만 사용합니다. Omnifaces Jar는 Maven으로 임포트 할 때 가능합니까? – omarbr

+0

자신 만의 Maven 저장소를 유지한다면 그렇습니다. 다른 대안은 2.5-SNAPSHOT을 사용하는 것입니다 (NPE에 quickfix를 작성한 후에). – BalusC

관련 문제