使用PrimePush时出现NullPointerException

当我尝试初始化我的eventBus时,我得到一个NullPointerException:

位于sun.reflect.NativeMethodAccessorImpl.invoke0(本地方法)的sun.reflect.NativeMethodAccessorImpl.invoke(未知来源)的de.mrsfinster.web.livefeed.bean.FeedBean.init(FeedBean.java:179)中的java.lang.NullPointerException在org.jboss.weld.interceptor.reader.SimpleInterceptorInvocation $ SimpleMethodInvocation.invoke(SimpleInterceptorInvocation.java:77)的java.lang.reflect.Method.invoke(未知来源)的sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源) org.jboss.weld.interceptor.chain.AbstractInterceptionChain.invokeNext(AbstractInterceptionChain.java:126)位于org.jboss.weld.interceptor的org.jboss.weld.interceptor.chain.AbstractInterceptionChain.invokeNextInterceptor(AbstractInterceptionChain.java:102)。在org.jboss.weld.bean.proxy.CombinedInterceptorAndDecoratorStackMethodHandler的org.jboss.weld.interceptor.proxy.InterceptorMethodHandler.invoke(InterceptorMethodHandler.java:28)中的proxy.InterceptorMethodHandler.executeInterception(InterceptorMethodHandler.java:43)。 在de.mrsfinster.web.livefeed.bean.FeedBean上调用(CombinedInterceptorAndDecoratorStackMethodHandler.java:53)$ org.jboss.weld.interceptor.util.InterceptionUtils.executePostConstruct中的$ Proxy $ _ $$ _ WeldSubclass.lifecycle_mixin _ $$ _ postConstruct(未知来源) (InterceptionUtils.java:38)org.jboss.weld.interceptor.util.InterceptionUtils.executePostConstruct(InterceptionUtils.java:50)atg.jboss.weld.injection.producer.BeanInjectionTarget.postConstruct(BeanInjectionTarget.java:68)at at Org.jboss.weld.bean.ManagedBean.create(ManagedBean.java:153)位于org.jboss.weld.context.AbstractContext的org.jboss.weld.util.bean.IsolatedForwardingBean.create(IsolatedForwardingBean.java:44)。在org.jboss.weld.context.PassivatingContextWrapper的$(AbstractContext.java:96)org.jboss.weld.manager.BeanManagerImpl.getReference(BeanManagerImpl.java:742)中的org.jboss.weld.manager.BeanManagerImpl.java:742)中的org.jboss.weld.context.PassivatingContextWrapper $ AbstractPassivatingContextWrapper.get(PassivatingContextWrapper.java:76) .jboss.weld.el.AbstractWeldELResolver.lookup(AbstractWeldELResolver.java:107)a t org.jboss.weld.el.AbstractWeldELResolver.getValue(AbstractWeldELResolver.java:90)at org.jboss.as.jsf.injection.weld.ForwardingELResolver.getValue(ForwardingELResolver.java:46)at javax.el.CompositeELResolver.getValue (CompositeELResolver.java:188)com.sun.faces.el.DemuxCompositeELResolver._getValue(DemuxCompositeELResolver.java:176)at com.sun.faces.el.DemuxCompositeELResolver.getValue(DemuxCompositeELResolver.java:203)at com.sun。 el.parser.AstIdentifier.getValue(AstIdentifier.java:116)at com.sun.el.parser.AstValue.getBase(AstValue.java:151)at com.sun.el.parser.AstValue.getTarget(AstValue.java: 170)在com.sun.el.parser.AstValue.invoke(AstValue.java:275)的com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:304)at org.jboss.weld.util.el.ForwardingMethodExpression .invoke(ForwardingMethodExpression.java:40)org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50)org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpress ion.java:40)at.com.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50)at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)at com.sun .faces.facelets.tag.jsf.core.DeclarativeSystemEventListener.processEvent(EventHandler.java:128)at javax.faces.component.UIComponent $ ComponentSystemEventListenerAdapter.processEvent(UIComponent.java:2584)at javax.faces.event.SystemEvent.processListener (SystemEvent.java:108)位于com.sun.faces的com.sun.faces.application.ApplicationImpl.processListeners(ApplicationImpl.java:2190)的javax.faces.event.ComponentSystemEvent.processListener(ComponentSystemEvent.java:118)。 application.ApplicationImpl.invokeComponentListenersFor(ApplicationImpl.java:2135)at com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:289)at com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:247)在org.jboss.as.jsf.injection.weld.ForwardingApplication.publishEvent(ForwardingApplicatio) n.java:299)com.sun.faces.lifecycle.RenderponsePhase.exe执行(RenderResponsePhase.java:107)com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)com.sun.faces .lifecycle.LifecycleImpl.render(LifecycleImpl.java:219)位于io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85)的javax.faces.webapp.FacesServlet.service(FacesServlet.java:647) io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:61)位于org.wildfly.extension.undertow.security的io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)。 SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131)在io.undertow.servlet.handlers.security.Serv letOuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:56)at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:45)at io .undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:63)at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:58)at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler .handleRequest(CachedAuthenticatedSessionHandler.java:70)ato.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76)ato.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)at org。 io.unde的wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61) rtow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)at io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler。 java:261)at io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:247)at io.undertow.servlet.handlers.ServletInitialHandler.access $ 000(ServletInitialHandler.java:76)at io.undertow.servlet。 handler.ServletInitialHandler $ 1.handleRequest(ServletInitialHandler.java:166)at io.undertow.server.Connectors.executeRootHandler(Connectors.java:197)at io.undertow.server.HttpServerExchange $ 1.run(HttpServerExchange.java:759)at java .util.concurrent.ThreadPoolExecutor.runWorker(未知来源)java.util.concurrent.ThreadPoolExecutor $ Worker.run(未知来源)java.lang.Thread.run(未知来源)

这是我的代码:

@PostConstruct public void init() { eventBus = EventBusFactory.getDefault().eventBus(); } 

我正在使用Primefaces 5.2,Wildfly 8.2.0.final,大气运行时2.4.0-RC3。

我的web.xml配置:

  Push Servlet org.primefaces.push.PushServlet   Push Servlet /primepush/*  

显然, EventBusFactory.getDefault()返回null。 将PrimeFaces升级到5.2后可能会出现此问题,并在此处进行了讨论。 尝试在启动时加载PushServlet以进行正确的初始化:

  Push Servlet org.primefaces.push.PushServlet 1  

只需将此代码放在默认构造函数中即可

 "eventBus = EventBusFactory.getDefault().eventBus();" 

它适用于任何版本。