在 Struts 2 中重用自定义表达式验证器



在Struts 2中,我们可以开发可用于应用程序范围的@CustomValidator

@CustomValidator(type = "CustomerNumberValidator", fieldName = "customerNo")

对于验证我们使用多个字段@ExpressionValidator

@ExpressionValidator(expression = 
"( (!''.equals(account.firstName) && (!''.equals(account.lastName) )
   || (presonalAccount == false)", 
   key = "validate.account.name")

如果表达式太复杂并且需要处理多个字段,我们使用 OGNL 调用静态方法。静态方法将执行验证并返回boolean例如

@ExpressionValidator(expression = "@foo.bar.CalendarUtil@compareDates(fromDate,toDate)", key = "validate.date.before")

以上是一些如何自定义表达式验证器!

我们在应用程序范围内使用@foo.bar.CalendarUtil@compareDates来为我们进行此验证。

有没有另一种方法可以让我们使用自定义范围的验证器?!

是否有任何自定义表达式验证器可以添加到 Struts,我们可以以使用 @CustomValidator 的方式在Action中调用它?

创建自定义验证器(与字段无关):

public final class CompareDatesValidator extends ValidatorSupport {
    private String fromDate; // getter and setter
    private String toDate;   // getter and setter    
    @Override
    public void validate(Object o) throws ValidationException {
        Date d1 = (Date)parse(fromDate, Date.class);
        Date d2 = (Date)parse(toDate, Date.class);
        if (d1==null || d2==null || d2.before(d1)){
            addActionError(getDefaultMessage());
        }
    }
}

validators.xml文件中注册自定义验证程序:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC
     "-//OpenSymphony Group//XWork Validator Config 1.0//EN"
     "http://www.opensymphony.com/xwork/xwork-validator-config-1.0.dtd">
<validators>
    <validator name="compareDatesValidator" 
              class="org.foo.bar.CompareDatesValidator"/>
</validators>

在操作中使用验证器:

private Date startDate; // getter and setter
private Date endDate;   // getter and setter
@Validations(
    customValidators={
        @CustomValidator(type="compareDatesValidator", 
            message="Dates provided are not valid."
            parameters={
                @ValidationParameter(name="fromDate", value="${startDate}"), 
                @ValidationParameter(name="toDate",   value="${endDate}")})})
public String execute(){
    return SUCCESS;
}

如果需要验证多个字段,可以使用非字段自定义验证程序。非字段自定义验证器应扩展ValidatorSupport并实现validate方法。然后在-validation.xml中应用自定义验证器或使用@CustomValidator注释。在这里,您可以添加自定义表达式作为@ValidationParameter,并在执行验证时对其进行解析。

注意:

我在这个答案中首先使用了这个技巧:

public class RetypeValidator extends ValidatorSupport {
  private String value = null;
  public String getValue() {
    return value;
  }
  public void setValue(String value) {
    this.value = value;
  }
  private String retypeValue = null;
  public String getRetypeValue() {
    return retypeValue;
  }
  public void setRetypeValue(String value) {
    retypeValue = value;
  }
  @Override
  public void validate(Object object) throws ValidationException {
    String value = (String) parse(this.value, String.class);
    String retypeValue = (String) parse(this.retypeValue, String.class);
    if (value != null && retypeValue != null && !value.equals(retypeValue))
      addActionError(getDefaultMessage());
  }
}

另一种选择是重写ActionSupportvalidate方法。对此方法的调用通过侦听器控制validation。此验证方法称为编程方法,默认情况下使用此方法,而不考虑在声明性验证期间应用的验证程序。

相关内容

  • 没有找到相关文章

最新更新