当我尝试渲染视图时,浏览器显示此错误
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库。
我不明白为什么渲染不起作用。
有什么建议吗?
亲切的问候。
答案 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;
}