4

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

java.lang.NullPointerException at de.mrsfinster.web.livefeed.bean.FeedBean.init(FeedBean.java:179) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)在 sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.jboss.weld.interceptor.reader.SimpleInterceptorInvocation$SimpleMethodInvocation.invoke(SimpleInterceptorInvocation.java:77) at org.jboss.weld.interceptor.chain.AbstractInterceptionChain.invokeNext(AbstractInterceptionChain.java:126) 在 org.jboss.weld.interceptor.chain.AbstractInterceptionChain.invokeNextInterceptor(AbstractInterceptionChain.java:102) 在 org.jboss.weld.interceptor。 proxy.InterceptorMethodHandler.executeInterception(InterceptorMethodHandler.java:43) 在 org.jboss.weld.bean.proxy.CombinedInterceptorAndDecoratorStackMethodHandler.invoke(CombinedInterceptorAndDecoratorStackMethodHandler.java:53) 在 de.mrsfinster.web 的 org.jboss.weld.interceptor.proxy.InterceptorMethodHandler.invoke(InterceptorMethodHandler.java:28) .livefeed.bean.FeedBean$Proxy$_$$_WeldSubclass.lifecycle_mixin_$$_postConstruct(Unknown Source) at org.jboss.weld.interceptor.util.InterceptionUtils.executePostConstruct(InterceptionUtils.java:38) at org.jboss.weld。 org.jboss.weld.injection.producer.BeanInjectionTarget.postConstruct(BeanInjectionTarget.java:68) 的拦截器.util.InterceptionUtils.executePostConstruct(InterceptionUtils.java:50) org.jboss.weld.bean.ManagedBean.create(ManagedBean. java:153) 在 org.jboss.weld.util.bean.IsolatedForwardingBean.create(IsolatedForwardingBean.java:44) at org.jboss.weld.context.AbstractContext.get(AbstractContext.java:96) at org.jboss.weld.context.PassivatingContextWrapper$AbstractPassivatingContextWrapper.get(PassivatingContextWrapper.java:76) at org.jboss.weld .manager.BeanManagerImpl.getReference(BeanManagerImpl.java:742) 在 org.jboss.weld.el.AbstractWeldELResolver.lookup(AbstractWeldELResolver.java:107) 在 org.jboss.weld.el.AbstractWeldELResolver.getValue(AbstractWeldELResolver.java:90) ) 在 com.sun.faces.el.DemuxCompositeELResolver 的 javax.el.CompositeELResolver.getValue(CompositeELResolver.java:188) 的 org.jboss.as.jsf.injection.weld.ForwardingELResolver.getValue(ForwardingELResolver.java:46)。 _getValue(DemuxCompositeELResolver.java:176) 在 com.sun.faces.el.DemuxCompositeELResolver.getValue(DemuxCompositeELResolver.java:203) 在 com.sun.el.parser.AstIdentifier.getValue(AstIdentifier.java:116) 在 com.sun.el.parser.AstValue.getBase(AstValue.java:151) 在 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) 在 org.jboss。 org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) at org.jboss.weld.util.el.ForwardingMethodExpression.invoke( ForwardingMethodExpression.java:40) at org.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。在 javax.faces 的 javax.faces.event.SystemEvent.processListener(SystemEvent.java:108) 在 javax.faces.component.UIComponent$ComponentSystemEventListenerAdapter.processEvent(UIComponent.java:2584) 的声明性SystemEventListener.processEvent(EventHandler.java:128) .event.ComponentSystemEvent.processListener(ComponentSystemEvent.java:118) 在 com.sun.faces.application.ApplicationImpl.processListeners(ApplicationImpl.java:2190) 在 com.sun.faces.application.ApplicationImpl.invokeComponentListenersFor(ApplicationImpl.java:2135) ) 在 com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:247) 在 org.jboss.as.jsf.injection 的 com.sun.faces.application.ApplicationImpl.publishEvent(ApplicationImpl.java:289)。 com.sun 上的weld.ForwardingApplication.publishEvent(ForwardingApplication.java:299)。faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:107) at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java: 219) 在 javax.faces.webapp.FacesServlet.service(FacesServlet.java:647) 在 io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85) 在 io.undertow.servlet.handlers.security.ServletSecurityRoleHandler .handleRequest(ServletSecurityRoleHandler.java:61) 在 io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36) 在 org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78) 在io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 在 io。undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131) 在 io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:56) 在 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) 在 io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler。handleRequest(CachedAuthenticatedSessionHandler.java:70) at io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76) at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) at org.wildfly .extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61) 在 io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 在 io.undertow.server.handlers.PredicateHandler.handleRequest (PredicateHandler.java:43) 位于 io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:247) 的 io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:261)。 servlet.handlers.ServletInitialHandler。访问$000(ServletInitialHandler.java:76) 在io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:166) 在io.undertow.server.Connectors.executeRootHandler(Connectors.java:197) 在io.undertow .server.HttpServerExchange$1.run(HttpServerExchange.java:759) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread .run(未知来源)runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source)runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source)

这是我的代码:

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

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

我的 web.xml 配置:

<servlet>
    <servlet-name>Push Servlet</servlet-name>
    <servlet-class>org.primefaces.push.PushServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>Push Servlet</servlet-name>
    <url-pattern>/primepush/*</url-pattern>
</servlet-mapping>
4

2 回答 2

6

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

<servlet>
    <servlet-name>Push Servlet</servlet-name>
    <servlet-class>org.primefaces.push.PushServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
于 2015-08-13T10:11:03.217 回答
-2

只需将此代码放在下面的默认构造函数中

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

它适用于任何版本。

于 2016-08-17T09:41:00.270 回答