JSF:如何验证字段并通过bean验证返回错误消息?

时间:2022-12-16 20:02:35

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:

使用 附加到特定组件的属性,该属性应该引用输入组件的id:

<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:

#1


10  

Either use <h:message> which you attach to specific components by for attribute which should refer the id of the input component:

使用 附加到特定组件的属性,该属性应该引用输入组件的id:

<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: