2016-07-26 4 views
1

1つのEARアーカイブに2つのJSFベースのWARプロジェクトがある場合、両方のプロジェクトは依存関係としてOmniFacesを持ち、 。仕事の罰金を展開し、1戦からOmniFacesを削除する場合org.omnifaces.cdi.eager.EagerBeansPhaseListener.afterPhaseのjava.lang.NullPointerExceptionあるEARに2つのWARがある場合

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、ペーシュ・カショーロ4.1.152

答えて

0

これはCDI仕様のunclarityによって引き起こされる既知の問題です。参照:

私は@EagerがマルチモジュールEARでテストされていなかったことを認めなければなりません。このNullPointerExceptionは残念ですが、Webアプリケーションをこのように使用できないようにすることは決してありません。たいていの場合、OmniFacesのCDI関連機能は使用できなくなりますが、残りの部分は引き続き機能するはずです。

これでissue 290を作成しました。マルチモジュールEARのすべてのCDI機能を、現在利用可能なサーバーに対してissue 281として再テストします。

ベストプラクティスは、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

関連する問題