Я попробовал следующий код (я следовал примеру), чтобы проверить дату, выбранную из календаря. Если дата не существует в моей базе данных, то сообщение об ошибке проверки должно быть показано конечному пользователю. Однако ошибка не заканчивается в <h:message>
, а записывается в журнал сервера.
Вид:
<p:calendar id="date1" value="#{bean.date1}" showOn="button">
<f:validator validatorId="calendarValidator" />
<f:ajax execute="date1" render="calendarmessage" />
</p:calendar>
<h:message id="calendarmessage" for="date1" />
Validator:
@FacesValidator("calendarValidator")
public class CalendarValidator implements Validator{
@Override
public void validate(FacesContext context, UIComponent component, Object value) {
java.util.Date date2 = (java.util.Date) value;
try {
if (validateDate(date2)) {
throw new ValidatorException(new FacesMessage("A valid date"));
} else {
throw new ValidatorException(new FacesMessage("date dont figure in the database"));
}
} catch(Exception e) {
e.printStackTrace();
}
}
}
Журнал сервера:
INFO: date invalide
GRAVE: javax.faces.validator.ValidatorException: date dont figure in the database
at DAOKPI.CalendarValidator.validate(CalendarValidator.java:60)
at javax.faces.component.UIInput.validateValue(UIInput.java:1149)
at javax.faces.component.UIInput.validate(UIInput.java:967)
at javax.faces.component.UIInput.executeValidate(UIInput.java:1233)
at javax.faces.component.UIInput.processValidators(UIInput.java:698)
at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1214)
at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1214)
at javax.faces.component.UIForm.processValidators(UIForm.java:253)
at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1214)
at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1214)
at javax.faces.component.UIViewRoot.processValidators(UIViewRoot.java:1172)
at com.sun.faces.lifecycle.ProcessValidationsPhase.execute(ProcessValidationsPhase.java:76)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:409)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1