java – 在CDI Passivation Capable bean中,是否可以重新注入非钝化能力依赖性而不是钝化?

在CDI钝化功能的bean中,是否可以重新注入非钝化能力的依赖性而不是钝化?

考虑以下代码:

@SessionScoped
public class UserData implements Serializable {
  @Inject
  private Logger log;
  private String data;
}


@ApplicationScoped
public class LoggerFactory {
  @Produces
  public Logger getLogger(){
  ...
  }
}

public class Logger {
...
}

所以Logger不是Serializable,但我真的不在乎.当反序列化UserData时,是否有可能以某种方式再次调用Logger的生产者?

编辑

最初的讨论从这里开始:

http://www.cdi-spec.org/news/2015/07/03/CDI-2_0-EDR1-released/#comment-2119769909

希望CDI专家组提出比@Instance更好的方法

最佳答案 检查
spec,你有答案. Logger不可序列化,因此Logger类型的bean不具备钝化功能.容器不提供您请求的技巧.

解决方案是编写类似的东西:

@SessionScoped
public class UserData implements Serializable {
  @Inject
  private Instance<Logger> logInstance;
  private String data;

  public Logger getLog() {
   return logInstance.get();
  }
}

Ans使用getLog()而不是登录代码.

点赞