【问题标题】:Why does Weld in GlassFish 4.1 call @PreDestroy method on already destroyed ViewScoped beans after call to invalidateSession?为什么 GlassFish 4.1 中的 Weld 在调用 invalidateSession 后对已销毁的 ViewScoped bean 调用 @PreDestroy 方法?
【发布时间】:2015-05-01 23:50:53
【问题描述】:

今天早上我注意到,当我的用户退出 Web 应用程序时,我在 GlassFish 4.1 上运行的 JSF 应用程序抛出以下错误:

  • WELD-000019:使用限定符 [@Default @Named @Any] 销毁托管 Bean [...MyAuthenticator] 的实例 null 时出错

MyAuthenticator 是一个带有 @PreDestroy 注释方法的 javax.faces.view.ViewScoped CDI bean。

作为测试,我去掉了@PreDestroy注解,验证错误消失了。

然后,我将 @PreDestroy 注释连同许多调试消息一起添加回 MyAuthenticator,并执行了以下测试:

测试 1

  1. 已登录应用程序。
  2. 退出应用程序。

测试 2

  1. 已登录应用程序。
  2. 允许会话过期。

调试消息在两个测试中都显示了以下行为:

  1. MyAuthenticator 已创建并显示登录表单。
  2. MyAuthenticator 在用户登录表单提交并用户登录后立即销毁。
  3. 当会话失效或过期时,Weld 会抛出报告的错误。

我相信错误是 Weld 在我已经销毁的 MyAuthenticator 上调用 @PreDestroy 方法的结果。

问题

  • 这是 Weld 中的错误吗?
  • 我可以放心地忽略吗?

【问题讨论】:

  • 我在 Tomcat 8.0.21 中使用 Weld 和 JSF 发生了类似的情况。你有没有发现什么,你仍然得到例外吗?
  • 我仍然看到这个问题,但没有进一步调查或记录错误报告。
  • 在 JBoss Wildfly 8.2.0.Final 上也是如此。
  • 我在 Tomcat 7+、Weld 和 JSF 上运行时遇到了同样的问题。你有什么办法可以解决这个问题吗? @Reed Elliott
  • 我也明白了。不知道该怎么办。

标签: jakarta-ee glassfish-4 weld


【解决方案1】:

此问题已在 GlassFish 4.1.2 中得到解决。

【讨论】:

  • 2021 年 Payara 5 上仍在发生
猜你喜欢
  • 2019-04-10
  • 1970-01-01
  • 2012-01-30
  • 1970-01-01
  • 2014-02-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多