I have a contact form and I have some fields that are validated by bean validation, how could I return bean validation error messages after submitting?
我有一个联系表单,我有一些通过bean验证验证的字段,如何在提交后返回bean验证错误消息?
For example:
<h:form>
<h:inputText id="name" value="#{contact.client.name}"></h:inputText>Name (Required)
<h:inputText id="email" value="#{contact.client.email}"></h:inputText>E-Mail (Required)
<h:inputText id="website" value="#{contact.client.website}"></h:inputText>Website (Optional)
<h:inputText id="text" value="#{contact.client.text}"></h:inputText>Message (Required):
<h:commandButton value="Send" action="#{contact.sendMessage}" >
<f:ajax execute="@form" render="@form"/>
</h:commandButton>
</h:form>
This is how I'm validating my fields:
这就是我验证字段的方式:
// Client.java (model)
@NotNull(message="Please provide your name")
private String name;
@NotNull(message="Please provide your email")
@Pattern(regexp = "([^.@]+)(\\.[^.@]+)*@([^.@]+\\.)+([^.@]+)", message = "Invalid e-mail")
private String email;
@Pattern(regexp = "(http[s]?://|ftp://)?(www\\.)?[a-zA-Z0-9-\\.]+\\.([a-zA-Z]{2,5})$", message = "Not valid URL")
private String website;
@NotNull(message="Please provide your message")
private String text;
1 个解决方案
#1
10
Either use <h:message>
which you attach to specific components by for
attribute which should refer the id
of the input component:
使用
<h:inputText id="name" value="#{contact.client.name}"></h:inputText>Name (Required)
<h:message for="name" />
<h:inputText id="email" value="#{contact.client.email}"></h:inputText>E-Mail (Required)
<h:message for="email" />
<h:inputText id="website" value="#{contact.client.website}"></h:inputText>Website (Optional)
<h:message for="website" />
<h:inputText id="text" value="#{contact.client.text}"></h:inputText>Message (Required):
<h:message for="text" />
or use <h:messages/>
to display them all at a single place:
或使用
<h:messages />
Yes, bean validation messages also ends in there.
是的,bean验证消息也在那里结束。
Don't forget to ensure that the button's render
attribute covers them as well.
不要忘记确保按钮的渲染属性也包含它们。
See also:
- JSF 2.0 tutorial with Glassfish and Eclipse - Hello World - The view
Glassfish和Eclipse的JSF 2.0教程 - Hello World - 视图
#1
10
Either use <h:message>
which you attach to specific components by for
attribute which should refer the id
of the input component:
使用
<h:inputText id="name" value="#{contact.client.name}"></h:inputText>Name (Required)
<h:message for="name" />
<h:inputText id="email" value="#{contact.client.email}"></h:inputText>E-Mail (Required)
<h:message for="email" />
<h:inputText id="website" value="#{contact.client.website}"></h:inputText>Website (Optional)
<h:message for="website" />
<h:inputText id="text" value="#{contact.client.text}"></h:inputText>Message (Required):
<h:message for="text" />
or use <h:messages/>
to display them all at a single place:
或使用
<h:messages />
Yes, bean validation messages also ends in there.
是的,bean验证消息也在那里结束。
Don't forget to ensure that the button's render
attribute covers them as well.
不要忘记确保按钮的渲染属性也包含它们。
See also:
- JSF 2.0 tutorial with Glassfish and Eclipse - Hello World - The view
Glassfish和Eclipse的JSF 2.0教程 - Hello World - 视图