[英]JBoss AS 7.1.1.Final: serverError: class java.lang.IllegalStateException on JSF 2 view validation
我在使用纯JSF 2页面时遇到问题。 加载页面时,将显示两个inputText和一个select。 每个字段的右侧都有一个验证字段。 这两个输入是必填字段,而select始终具有一个选择,因此它根本不会验证(至少不应该验证)。
这是屏幕截图:
这是单击“创建”按钮时显示的内容。 重新点击“创建”按钮时,将出现以下弹出窗口:
OK,没有代码就什么也没有,这里是XHTML:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html">
<h:head>
</h:head>
<h:body>
<h:form>
<h:panelGrid columns="3" id="base-data-grid">
<h:outputLabel value="Name:*" for="name-input" />
<h:inputText value="#{testBean.name}"
requiredMessage="Name required!"
id="name-input">
<f:validateRequired />
</h:inputText>
<h:message for="name-input" style="color: red;" />
<h:outputLabel value="Code:*" for="code-input" />
<h:inputText value="#{testBean.code}"
requiredMessage="Code required!"
id="code-input">
<f:validateRequired />
</h:inputText>
<h:message for="code-input" style="color: red;" />
<h:outputLabel value="Location:" for="location-select" />
<h:selectOneMenu value="#{testBean.location}"
converter="#{testConverter}"
id="location-select">
<f:selectItems value="#{testBean.locations}"
var="l"
itemValue="#{l}"
itemLabel="#{l.name}" />
</h:selectOneMenu>
<h:message for="location-select" style="color: red;" />
</h:panelGrid>
<h:panelGrid columns="1">
<h:commandButton value="Create"
action="#{testBean.create}">
<f:ajax execute="base-data-grid" render="base-data-grid lalala" />
</h:commandButton>
</h:panelGrid>
<h:messages id="lalala" />
</h:form>
</h:body>
</html>
选择的位置类(仅是名称):
public class Location
{
private String name;
public Location(String name)
{
this.name = name;
}
public String getName()
{
return name;
}
}
转换器(作为CDI版本):
import javax.enterprise.context.RequestScoped;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
import javax.inject.Inject;
import javax.inject.Named;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Named
@RequestScoped
public class TestConverter implements Converter
{
private static final Logger log = LoggerFactory.getLogger(TestConverter.class);
@Inject
private TestBean testBean;
@Override
public Object getAsObject(FacesContext arg0, UIComponent arg1, String name)
{
log.info(getClass().getSimpleName() + ".getAsObject: " + name);
return testBean.getLocationFor(name);
}
@Override
public String getAsString(FacesContext arg0, UIComponent arg1, Object obj)
{
log.info(getClass().getSimpleName() + ".getAsString: " + obj);
return ((Location)obj).getName();
}
}
和测试bean:
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.enterprise.context.SessionScoped;
import javax.inject.Named;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Named
@SessionScoped
public class TestBean implements Serializable
{
private static final Logger log = LoggerFactory.getLogger(TestBean.class);
private String name;
private String code;
private Location location;
private List<Location> locations;
@PostConstruct
public void init()
{
locations = new ArrayList<Location>();
locations.add(new Location("Berlin"));
locations.add(new Location("London"));
locations.add(new Location("New York"));
locations.add(new Location("Moscow"));
locations.add(new Location("Bejing"));
location = locations.get(2);
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
public String getCode()
{
return code;
}
public void setCode(String code)
{
this.code = code;
}
public Location getLocation()
{
return location;
}
public void setLocation(Location location)
{
this.location = location;
}
public List<Location> getLocations()
{
return locations;
}
public void setLocations(List<Location> locations)
{
this.locations = locations;
}
public void create()
{
log.info("Creating new whatever...");
}
// for converter to mimic DB query
public Location getLocationFor(String name)
{
for ( Location location : locations )
{
if ( location.getName().equals(name) )
{
return location;
}
}
return null;
}
}
如您所见,该页面应该做的事情不多。 验证两个输入字段,显示select并调用testBean.create(如果所有方法均已通过验证)。
但是,一旦验证运行一次,随后的每次“创建”按钮单击都会导致该serverError。
注意,如果您完全删除f:selectItems或h:selectOneMenu,则该页面将按预期工作。 这实际上使整个事情变得如此奇怪...
我不知道这是怎么回事。 有人知道怎么了吗?
我在这里附加了一个JBoss AS 7测试应用程序: https : //community.jboss.org/thread/202501 (重复帖子,对不起,需要很多帮助)。
请看一下这个极其奇怪的IllegalStateException。 JBAS server.log中什至没有任何东西...
PS:Mojarra版本当然是2.1.7(JBoss AS 7.1.1.Final附带的版本)
您的问题是该Location
需要可序列化
(实现java.io.Serializable
接口)
f:validateRequired
标记使ajax执行required-validation。
在此ajax请求的RestoreView阶段,由于位置不可序列化,运行时会遇到InstantiationException。
老实说,我不知道为什么不记录包括stacktrace在内的错误。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.