一、定义自己的验证器
您可以自订自己的验证器,所需要的是实现javax.faces.validator.Validator接口,例如我们实作一个简单的密码验证器,检查字元长度,以及密码中是否包括字元与数字:
PasswordValidator.java
package wsz.ncepu;
import javax.faces.application.FacesMessage;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.validator.Validator;
import javax.faces.validator.ValidatorException;
public class PasswordValidator implements Validator {
public void validate(FacesContext context, UIComponent component, Object obj)
throws ValidatorException {
String password = (String) obj;
if (password.length() < 6) {
FacesMessage message = new FacesMessage(
FacesMessage.SEVERITY_ERROR, "密码长度小于6", "密码长度不能小于6位");
throw new ValidatorException(message);
}
if (password.matches(".+[0-9]+")) {
FacesMessage message = new FacesMessage(
FacesMessage.SEVERITY_ERROR, "密码必须包含字母", "密码必须包含字母");
throw new ValidatorException(message);
}
}
}
如果验证错误,则丢出一个ValidatorException,它接受一个FacesMessage物件,这个物件接受三个参数,分别表示讯息的严重程度(INFO、 WARN、ERROR、FATAL)、讯息概述与详细讯息内容,这些讯息将可以使用<h:messages>或<h: message>标籤显示在页面上。
接下来要在faces-config.xml中注册验证器的识别(Validater ID),要加入以下的内容:
faces-config.xml
<validator>
<validator-id>passwordValidator</validator-id>
<validator-class>wsz.ncepu.PasswordValidator</validator-class>
</validator>
要使用自订的验证器,我们可以使用<f:validator>标签并设定validatorId属性,例如:
<h:inputSecret value="#{user.password}" required="true">
<f:validator validatorId="passwordValidator"/>
</h:inputSecret>
运行效果如下:
![](https://img-my.csdn.net/uploads/201212/19/1355908262_8035.png)
![](https://img-my.csdn.net/uploads/201212/19/1355908273_6045.png)
二、让Bean自行负责验证的工作
您也可以让Bean自行负责验证的工作,可以在Bean上提供一个验证方法,这个方法没有传回值,并可以接收FacesContext、UIComponent、Object三个参数,例如:
UserBean.java
package wsz.ncepu;
import javax.faces.application.FacesMessage;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.validator.ValidatorException;
public class UserBean {
private String name;
private String password;
private String errMessage;
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setPassword(String password) {
this.password = password;
}
public String getPassword() {
return password;
}
public void setErrMessage(String errMessage) {
this.errMessage = errMessage;
}
public String getErrMessage() {
return errMessage;
}
public String verify() {
if (!name.equals("justin") || !password.equals("123456")) {
errMessage = "名称或密码错误";
return "failure";
} else {
return "success";
}
}
public void validate(FacesContext context, UIComponent component, Object obj)
throws ValidatorException {
String password = (String) obj;
if (password.length() < 6) {
FacesMessage message = new FacesMessage(
FacesMessage.SEVERITY_ERROR, "密码长度小于6", "密码长度不能小于6位");
throw new ValidatorException(message);
}
if (password.matches(".+[0-9]+")) {
FacesMessage message = new FacesMessage(
FacesMessage.SEVERITY_ERROR, "密码必须包含字母", "密码必须包含字母");
throw new ValidatorException(message);
}
}
}
接着可以在页面下如下使用验证器:
<h:inputSecret value="#{user.password}"
required="true"
validator="#{user.validate}"/>
运行效果和上面一模一样