struts2 验证框架

 


1. struts2 的验证框架的分类
     1.1 验证的分类:
           1.1.1 根据验证的场所分:
                    客户端校验 在提交服务器前的效验,javascript的效验
                    服务端校验 在Action处理之前进行效验
              1.1.2 在使用方式上分
                         使用覆盖validate方法校验
     XML配置文件配置
     Java Annotation配置

2. Struts 2 验证流程
          Struts 2 执行步骤:
               
          Struts 2 验证步骤:
               
    1. 类型转换器负责对字符串的请求参数执行类型转换,并将这些值设置成 Action 的属性值
    2. 在执行类型转换过程中可能出现异常,如果出现异常,将异常信息保存到 ActionContext 中,
          conversionError 拦截器负责将其封装到 fieldError 里,然后执行第 3 步;如果转换过程没有异常信息,则直接进入第 3 步。
    3. 调用 Struts 2 内置的输入校验规则进行输入校验 (也就是根据各种 *validation.xml 文件里定义的校验进行输入校验)
    4.  通过反 射调用 validateXxx() 方法,其中 Xxx 是即将处理用户请求的处理逻辑所对应的方法名。
    5. 调用 Action 类里的 validate() 方法
    6. 如果经过上面 5 步 都没有出现 FieldError ,将调用 Action 里处理用户请求的处理方法;
          如果出现了 FieldError,系统将转入 input 逻辑视图所指定的视图资源。
    

3. 使用覆盖validate方法校验
     ActionSupport实现了接口Validatable
     通过重写 ActionSupport 类的 validate() 方法进行校验
     如果某个Action类中有多个执行方法XXX,可以通过增加validateXXX()方法来实现验证
    

4. XML配置文件配置
     Xml配置文件与Action的关系为:
          SomeAction.java – SomeAction-validation.xml
且与SomeAction.class处在相同的目录中。

在使用params传值的情况适合该验证。

在使用modeldriver传值的时候,可以采用visitor效验器
Visitor 校验器主要用于校验 Action 里的复合属性。
例如:一个 SomeActionAction 里包含了 User 类型的属性,该校验器需要配置属性的validation.xml
eg:
     SomeAction-validation.xml
     User-validation.xml
缺点:
     多个xml文件,难于管理


5. Java Annotation配置
     5.1 拦截器配置
          <interceptor-ref name="validation">
               <param name="excludeMethods">input,back,cancel,browse</param>
               <param name="validateAnnotatedMethodOnly">true</param>
          </interceptor-ref>
 
     5.2 对于Action方法的效验方式
          eg:
          @Validations(
        requiredStrings = {
            @RequiredStringValidator(type = ValidatorType.SIMPLE, fieldName = "model.name", message = "产品名称是必须的."),
        }
    )
public String save(){        
        return SUCCESS;
}
备注:如果该action中其它方法不需要验证需要在方法上面加入:@SkipValidation 忽略验证
          eg:
               @SkipValidation
     public String toAdd(){
        return SUCCESS;
     }                    
          如果需要使用国际化只需在@RequiredStringValidator(type = ValidatorType.SIMPLE, fieldName = "model.name", key= "name.key")其它都遵循i18n的处理方式
     5.3 velocity模板展示提示信息方式
          采用s标签:
          输出所有的提示信息
          #sfielderror()
          输出字段model.name的提示信息
          #sfielderror("fieldName=model.name")
          
     5.4 自定义效验
          5.4.1 主要依赖于CustomValidator
          
          5.4.2 基本的使用:
               5.4.2.1 定义验证类型
                    eg:
                    package com.jd.vc.webapp.utils.validators;

import com.opensymphony.xwork2.validator.ValidationException;
import com.opensymphony.xwork2.validator.validators.FieldValidatorSupport;
/**
* Date: 13-2-20
* Time: 上午9:55
* To change this template use File | Settings | File Templates.
*/
public class NumberFieldValidator extends FieldValidatorSupport {
    public void validate(Object object) throws ValidationException {
        String fieldName = getFieldName();
        Object value = this.getFieldValue(fieldName, object);
        if (!(value instanceof String)) {
            return;
        }
        String str = ((String) value).trim();
        if (str.length() == 0) {
            return;
        }
        try {
            Double.parseDouble(str);
        } catch (NumberFormatException nfe) {
            addFieldError(fieldName, object);
            return;
        }
        try {
            Integer.parseInt(str);
        } catch (NumberFormatException nfe) {
            addFieldError(fieldName, object);
            return;
        }
    }
}
               
     5.4.2.2 加入验证框架
          加入validators.xml
          eg:
          <!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="numericField" class="com.jd.vc.webapp.utils.validators.NumberFieldValidator"/>
</validators>

     5.4.2.3 Action验证使用
          eg:
               @Validations(
        customValidators = {
            @CustomValidator(type ="numericField", fieldName = "model.weight", message = "请输入数字类型.")
        }
    )
     public String save(){        
          return SUCCESS;
     }
 
     5.4.2.4 velocity展示提示信息
          eg:
               输出字段model.weight的提示信息
                         #sfielderror("fieldName=model.weight")
 
参考地址:
annotation验证:
     http://www.tutorialspoint.com/struts_2/struts_annotations_types.htm
 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值