@ManagedBean(name =“foo”)在EL#{foo}中的名称不可用

时间:2015-05-17 13:39:15

标签: jsf jsf-2 managed-bean

我正在尝试在JSF2中使用应用程序范围的bean,但由于某种原因,我的请求范围bean中始终是null。这是我正在使用的代码:

应用程序作用域bean:

@ManagedBean(eager=true, name="applicationTracking")
@ApplicationScoped
public class ApplicationTracking implements Serializable {
    private static final long serialVersionUID = 4536466449079922778L;

    public ApplicationTracking() {
        System.out.println("ApplicationTracking constructed");
    }
}

请求范围的bean:

@ManagedBean
@RequestScoped
public class SearchResults implements Serializable {    
    private static final long serialVersionUID = 4331629908101406406L;

    @ManagedProperty("#{applicationTracking}")
    private ApplicationTracking appTracking;

    public ApplicationTracking getAppTracking() {
        return appTracking;
    }

    public void setAppTracking(ApplicationTracking appTrack) {
        this.appTracking = appTrack;
    }

    @PostConstruct
    public void init() {
        System.out.println("SearchResults.init CALLED, appTracking = " + appTracking);
    }
}

根据我在论坛中看到的一切,这应该没有任何其他配置。当我启动服务器(Tomcat)时,我看到ApplicationTracking构造函数和init方法被调用。

但在我的SearchResults组件中,PostConstruct中的打印输出始终为空:

SearchResults.init CALLED, appTracking = null 

我错过了什么?

1 个答案:

答案 0 :(得分:3)

如果您从正确的包javax.faces.bean.*导入了这些注释,那么如果您在faces-config.xml中在不同的托管bean名称上重新注册了相同的托管bean类,则会出现此问题。摆脱那个faces-config.xml条目。这是注册托管bean的JSF 1.x风格。你在JSF 2.x中不需要它。无论如何,当你这样做时,它将覆盖托管bean类上任何基于注释的注册,导致它们无效。

确保在学习和使用JSF 2.x时不要阅读JSF 1.x目标资源。在JSF 2.x中,许多事情都有所不同。