【问题标题】:JSF initialization fails with @ViewScopedJSF 初始化失败,@ViewScoped
【发布时间】:2020-09-28 11:27:03
【问题描述】:

我正在 MyFaces 2.3.6 上使用 Primefaces 8.0 构建 JSF 2.3 应用程序,在 Tomcat 9 上运行。同时使用 OpenWebBeans 2.0.18。

当我将范围从 @RequestScoped 更改为 @ViewScoped 时,我的一个 bean(控制器)给了我一个错误:

28-Sep-2020 13:12:07.368 SEVERE [main] org.apache.myfaces.webapp.AbstractFacesInitializer.initFaces An error occured while initializing MyFaces: It's not allowed to call getReference(Bean, Type, CreationalContext) before AfterDeploymentValidation
java.lang.IllegalStateException: It's not allowed to call getReference(Bean, Type, CreationalContext) before AfterDeploymentValidation
    at org.apache.webbeans.container.InjectableBeanManager.checkAfterDeploymentValidationFired(InjectableBeanManager.java:434)
    at org.apache.webbeans.container.InjectableBeanManager.getReference(InjectableBeanManager.java:178)
    at org.apache.myfaces.cdi.util.CDIUtils.resolveInstance(CDIUtils.java:65)
    at org.apache.myfaces.cdi.util.CDIUtils.lookup(CDIUtils.java:52)
    at org.apache.myfaces.flow.cdi.DefaultCDIFacesFlowProvider.getAnnotatedFlows(DefaultCDIFacesFlowProvider.java:52)
    at org.apache.myfaces.flow.impl.AnnotatedFlowConfigurator.configureAnnotatedFlows(AnnotatedFlowConfigurator.java:42)
    at org.apache.myfaces.config.FacesConfigurator.configureFlowHandler(FacesConfigurator.java:1713)
    at org.apache.myfaces.config.FacesConfigurator.configure(FacesConfigurator.java:619)
    at org.apache.myfaces.webapp.AbstractFacesInitializer.buildConfiguration(AbstractFacesInitializer.java:456)
    at org.apache.myfaces.webapp.Jsp21FacesInitializer.initContainerIntegration(Jsp21FacesInitializer.java:70)
    at org.apache.myfaces.webapp.AbstractFacesInitializer.initFaces(AbstractFacesInitializer.java:190)
    at org.apache.myfaces.webapp.StartupServletContextListener.contextInitialized(StartupServletContextListener.java:103)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4685)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5146)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
    at java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:134)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909)
    at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:841)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
    at java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:134)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909)
    at org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:262)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.StandardService.startInternal(StandardService.java:421)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:930)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:633)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:344)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:475)

bean 代码是这样的:

@Named
@ViewScoped
@ManagedBean
public class DashBoardController implements Serializable
{
    private static final long serialVersionUID = 1L;
    private static final Logger logger = Logger.getLogger(DashBoardController.class.getName());

    List<IdentityStatistics> idStats;
    List<AuditStatistics> auditStats;

    @Inject
    private StatisticsService service;

    @PostConstruct
    public void init()
    {
        logger.log(Level.FINE, "Reading statistics from API");
        FacesContext context = FacesContext.getCurrentInstance();
        AuthToken token =    (AuthToken)context.getExternalContext().getSessionMap().get(AuthService.SESSION_TOKEN);
        ...
    }
    ...
}

切换回@RequestScoped 会立即解决错误(但这不是我想要的)。错误中提到的getReference()方法肯定不在我的代码中,所以它一定在某个框架库中。

我有另一个非常相似的@ViewScoped bean,它 给我这个错误。 显然我错过了某个地方的差异,但对于我的生活,我无法发现它。

使用@ViewScoped 时可能导致此错误的原因是什么?

【问题讨论】:

  • 删除注解@ManagedBean
  • 请始终发布整个堆栈跟踪
  • @tandraschko 添加了完整的堆栈跟踪!
  • @raupach 我现在意识到我正在使用两个不同的注释来完成同样的事情。我删除了@ManagedBean,但它并没有解决错误。

标签: jsf primefaces myfaces openwebbeans


【解决方案1】:

好的。简单的答案是:失败的 bean 包含的使用 @InjectStatisticsService 服务没有实现 Serializable

在没有问题的请求范围内,显然在其他范围内需要保留状态。

如果这个错误不那么神秘,那就太好了。

【讨论】:

  • 通常它不是那么神秘,也许您之前在日志中错过了错误/警告?否则我的 IDE 总是会提醒这一点。
  • 所以StatisticsService 不是EJB?例如。 @Stateless。这不需要在 EJB impl 上显式声明 Serializable
  • @BalusC 不,它不是带注释的 EJB。我仍在研究何时以及如何使用这些功能 - 我使用的许多后端服务同时使用无状态和有状态方法,这是功能设计的结果。
猜你喜欢
  • 1970-01-01
  • 2014-06-21
  • 2020-09-13
  • 2013-11-20
  • 1970-01-01
  • 2016-03-25
  • 2012-11-17
  • 2017-12-10
  • 2018-09-17
相关资源
最近更新 更多