uask自定义校验器:
自定义验证器必须实现 Validator 接口,为了简化校验器的开发,框架提供了两个抽象类ValidatorSupport 和FieldValidatorSupport。其中ValidatorSupport【用于定义非字段优先的校验器】 和 FieldValidatorSupport【用于字段优先的校验器】 实现了 Validator 接口,同时提供了用于实现数据校验的通用方法。
实现用户名称的唯一性校验---自定义校验器
- 继承FieldValidatorSupport实现字段有限的校验器
public class UniqueNameValidator extends FieldValidatorSupport {
@Override public void validate(Object object) throws ValidationException { // 覆盖定义validate方法实现数据校验逻辑 String name = this.getFieldName();// 获取输入域的名称<input>的name值 String value = this.getFieldValue(name, object).toString();// 获取用户输入的数据,已经完成了数据类型转换,可以直接获取到转换后的结果 // 具体的验证处理逻辑 if (value != null && value.trim().length() > 0) { IUserServ userv = ServiceFactory.getUserService(); boolean bb = userv.existsName(value); if(bb){//验证没有通过,用户名称已经存在,添加配置的默认报错信息 this.addFieldError(name, this.getDefaultMessage()); } } } } |
如果不是很通用的校验,比较建议使用validateXxxx的方法实现,不建议自定义校验器 |
如果使用了自定义校验方法validateXXX和校验框架两种方法,请注意没有互斥,两个都会被执行 |
2、注册校验器
将struts2-core.jar中/com/opensymphony/xwork2/validator/validators/default.xml拷贝到src根路径下,并更名为validators.xml,然后添加自定义校验器的说明
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE validators PUBLIC "-//Apache Struts//XWork Validator Definition 1.0//EN" "http://struts.apache.org/dtds/xwork-validator-definition-1.0.dtd"> <validators> <validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator" /> <validator name="requiredstring" class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator" /> <validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator" /> <validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator" /> <validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator" /> <validator name="double" class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator" /> <validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator" /> <validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator" /> <validator name="fieldexpression" class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator" /> <validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator" /> <validator name="creditcard" class="com.opensymphony.xwork2.validator.validators.CreditCardValidator" /> <validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator" /> <validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator" /> <validator name="conversion" class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator" /> <validator name="stringlength" class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator" /> <validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator" /> <validator name="conditionalvisitor" class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator" /> <validator name="uniqueName" class="com.edu.action.validator.UniqueNameValidator" /> </validators> |
3、在校验规则说明文件中引用自定义的校验器uniqueName
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE validators PUBLIC "-//Apache Struts//XWork Validator 1.0.3//EN" "http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd"> <validators> <field name="username"> <field-validator type="requiredstring" short-circuit="true"> <message>用户名称必须填写!</message> </field-validator> <field-validator type="stringlength" short-circuit="true"> <param name="minLength">6</param> <param name="maxLength">20</param> <message>用户名称应该在${minLength}到${maxLength}个字符之间!</message> </field-validator> <field-validator type="uniqueName"> <message>用户名称已经被占用!</message> </field-validator> </field> </validators> |
自定义类型转换器---日期格式的问题
Struts2中数据类型转换实际上是依赖于OGNL实现的,OGNL提供了TypeConverter接口,可以自定义实现这个接口实现自定义数据类型转换器。OGNL为了方便自定义扩展提供了一个类DefaultTypeConverter,这个类中提供了类型转换方法,可以覆盖定义
public Object convertValue(Map context上下文, Object value需要转换的数据,可能是String[], Class toType需要转换到的目标类型).
Struts2为了进一步进化自定义类型转换器,提供了抽象父类StrutsTypeConverter
- 继承StrutsTypeConverter自定义日期类型转换器,默认格式为yyyy-MM-dd
public class DateConverter extends StrutsTypeConverter { private DateFormat df = new SimpleDateFormat("yyyy-MM-dd"); public Object convertFromString(Map context, String[] values, Class toClass) { // 从字串类型转换为日期类型,一般在接收用户提交数据时使用 if (values != null && values.length > 0) { String ss = values[0]; if (ss != null && ss.trim().length() > 0) { try { return df.parse(ss.trim()); } catch (Exception e) { throw new IllegalArgumentException("数据格式错误!"); 校验器conversion用于捕获转换异常 } } } return null; } public String convertToString(Map context, Object o) { // 从日期类型转换为字串类型,一般在显示数据时使用 if (o != null && o instanceof Date) { Date dd = (Date) o; return df.format(dd); } return ""; }
}
|
2、注册数据类型转换器
Struts2中注册类型转换器有2种方法:全局注册和局部注册
局部注册:配置文件的名称和需要使用转换器的类名称一致,例如UserAction-conversion.properties,位置和UserAction位置相同,其中的内容是”属性名称=具体的转换器的类的全名”,例如birth=com.yan.DateConverter。这个转换器只对UserAction中的birth属性有效
全局注册,src/xwork-conversion.properties
java.util.Date= com.yan.DateConverter
当前应用中的所有java.util.Date都是使用DateConverter进行转换
3、在数据类型转换失败时,首先需要通过conversion来拦截类型报错,然后需要覆盖定义系统的默认报错Invalid field value for field "birth".
<field name="birth"> <field-validator type="conversion" short-circuit="true"> <message>输入日期格式应该为1999-2-23的样式!</message> </field-validator> |
定义全局资源文件
<constant name="struts.custom.i18n.resources" value="msgs"/>
在src/根目录先定义msgs.properties文件
其中内容为
xwork.default.invalid.fieldvalue= |