1

我想@SessionScoped使用@ManagedProperty. 总之就是想访问secondBean中firstBean的name属性。

@ManagedBean
@SessionScoped
public class FirstBean implements Serializable{
    private String name;
    //...other attributes
    //...constructor
    public String getSelectedModel() {
        return selectedModel;
    }

    public void setSelectedModel(String selectedModel) {
        this.selectedModel = selectedModel;
    }
    //other getters&setters
}

第二个豆子:

@ManagedBean
@SessionScoped
public class SecondBean implements Serializable{

@ManagedProperty(value="#{firstBean}")
private FirstBean firstBean

public SecondBean() {
    System.out.println(firstBean.getName());
}
public IndexBean getFirstBean() {
    return firstBean;
}

public void setFirstBean(FirstBean firstBean) {
    this.firstBean = firstBean;
}

当我运行这个时,我总是NullPointerExceptionSystem.out.println(firstBean.getName());第二个 bean 的构造函数中,这似乎意味着我需要创建一个新的firstBean.

但奇怪的是,当我注释掉这一行时,我可以毫无错误地做这样的事情,这意味着 firstBean 实际上是 secondBean 的一个属性。

<h:outputText value="#{secondBean.firstBean.name}" />

这里有什么问题?

4

1 回答 1

2

无法在构造函数中访问注入的依赖项。您基本上期望 Java 能够执行以下操作:

SecondBean secondBean; // Declare.
secondBean.firstBean = new FirstBean(); // Inject.
secondBean = new SecondBean(); // Construct.

如果尚未构造实例,则绝对不可能设置实例变量。相反,它的工作原理如下:

SecondBean secondBean; // Declare.
secondBean = new SecondBean(); // Construct.
secondBean.firstBean = new FirstBean(); // Inject.

然后,为了根据注入的依赖项执行业务操作,请使用带有注释的方法@PostConstruct。它将在构造依赖注入之后由依赖注入管理器直接调用。

所以,只需更换

public SecondBean() {
    System.out.println(firstBean.getName());
}

经过

@PostConstruct
public void init() { // Note: method name is fully to your choice.
    System.out.println(firstBean.getName());
}
于 2013-06-11T16:06:04.890 回答