JSF2 - javax.el.PropertyNotFoundException。不使用方法

时间:2012-03-08 00:58:44

标签: jsf jsf-2 icefaces

当我尝试渲染视图时,浏览器显示此错误

01:46:11,371 GRAVE [javax.enterprise.resource.webcontainer.jsf.application] (http--127.0.0.1-8080-1) Error Rendering View[/index.xhtml]: javax.el.PropertyNotFoundException: /index.xhtml @15,74 value="#{actividades.getAll}": The class 'org.pfc.controller.principal.ActividadesController' does not have the property 'getAll'.
at com.sun.faces.facelets.el.TagValueExpression.getValue(TagValueExpression.java:111) [jsf-impl-2.1.5-jbossorg-1.jar:2.1.5-SNAPSHOT]

ActvidadController代码

@ManagedBean(name="actividades")
@ViewScoped public class ActividadesController implements Serializable {

    private static final long serialVersionUID = 1L;

    private final static Log logger=LogFactory.getLog(ActividadesController.class);

    @ManagedProperty(value="#{actividadBO}")
    private ActividadBO actividad;



    public void setActividad(ActividadBO actividad) {
        this.actividad = actividad;
    }

    public List<Actividad> getAll(){

        logger.trace("ActividadesController.getAll");

        return actividad.getAll();
    }
}

查看代码

    <h:body>
        <ui:composition template="/WEB-INF/templates/main-template.xhtml">
            <ui:define name="content">
                <h:dataTable value="#{actividades.getAll}" var="actividad">
                    <h:column>
                        <f:facet name="header">
                            <h:outputText>Título</h:outputText>
                        </f:facet>
                        <h:outputText value="{actividad.titulo}"></h:outputText>
                    </h:column>
                </h:dataTable>
            </ui:define>
        </ui:composition>
</h:body>

我使用JBOSS 7,我的项目有el-impl2.2.jar,el-api.1.1.jar和icefaces3库。

我不明白为什么渲染不起作用。

有什么建议吗?

亲切的问候。

1 个答案:

答案 0 :(得分:10)

下面,

<h:dataTable value="#{actividades.getAll}" var="actividad">

您的EL表达无效。它正在寻找方法getGetAll(),但您只有getAll()方法表示(虚构)属性all的getter。该属性根本不需要存在(无论如何它都应该是private)。

因此,要解决您的问题,必须

<h:dataTable value="#{actividades.all}" var="actividad">

或者,如果您使用的是EL 2.2(但不推荐这种方式)

<h:dataTable value="#{actividades.getAll()}" var="actividad">

无论哪种方式,它都会调用正确的getAll()方法。


对于具体问题,

无关,您的代码中存在另一个设计缺陷。 EL需要多次调用getter才能解析它。在getter方法中执行业务/数据库访问作业是个坏主意。 getter应该只是返回bean属性。而是将DB作业移出到bean的(post)构造函数。

private List<Actividad> all;

@PostConstruct
public void init() {
    all = actividad.getAll();
}

public List<Actividad> getAll(){
    logger.trace("ActividadesController.getAll");
    return all;
}

另见: