在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()而不是登录代码.