У меня проблема с p: selectOneMenu, независимо от того, что я делаю, я не могу заставить JSF вызывать сеттер на сущности JPA. Подтверждение JSF не удается с этим сообщением:
form: location: Ошибка проверки: значение недействительно
У меня есть работа над несколькими другими классами одного и того же типа (т.е. соединять классы таблиц), но я не могу за свою жизнь заставить эту работу работать.
Если кто-то может бросить некоторые советы по устранению неполадок/отладки для этой проблемы, мы будем очень благодарны.
С помощью операторов журнала я проверил следующее:
-
Conveter
возвращает правильные значения неnull
. - У меня нет Bean Проверка в моих сущностях JPA.
- Отправитель
setLocation(Location location)
никогда не вызывается.
Это самый простой пример, который я могу сделать, и он просто не будет работать:
<h:body>
<h:form id="form">
<p:messages id="messages" autoUpdate="true" />
<p:selectOneMenu id="location" value="#{locationStockList.selected.location}" converter="locationConverter">
<p:ajax event="change" update=":form:lblLocation"/>
<f:selectItems value="#{locationStockList.locationSelection}"/>
</p:selectOneMenu>
</h:form>
</h:body>
Преобразователь
@FacesConverter(forClass=Location.class, value="locationConverter")
public class LocationConverter implements Converter, Serializable {
private static final Logger logger = Logger.getLogger(LocationConverter.class.getName());
@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
if (value.isEmpty())
return null;
try {
Long id = Long.parseLong(value);
Location location = ((LocationManagedBean) context.getApplication().getELResolver().getValue(context.getELContext(), null, "location")).find(id);
logger.log(Level.SEVERE, "Converted {0} to {1}" , new Object[] {value, location});
return location;
} catch (NumberFormatException e) {
return new Location();
}
}
@Override
public String getAsString(FacesContext context, UIComponent component, Object value) {
if (value == null || value.toString().isEmpty() || !(value instanceof Location))
return "";
return String.valueOf(((Location) value).getId());
}
}
Выход консоли:
// Getter method
INFO: Current value=ejb.locations.Location[id=null, name=null, latitude=0.0, longitude=0.0]
// Session Bean
INFO: Finding ejb.locations.Location with id=3
// Session Bean
INFO: ### Returning : ejb.locations.Location[id=3, name=mdmd, latitude=4.5, longitude=2.3]
// Converter
SEVERE: Converted 3 to ejb.locations.Location[id=3, name=mdmd, latitude=4.5, longitude=2.3]
// Getter method -> Where did my selected Location go ??
INFO: Current value=ejb.locations.Location[id=null, name=null, latitude=0.0, longitude=0.0]