WebWork2源码分析续三

最后我打算分析一下WebWork2.x中的输入校检部分,校检数据通常包括客户端检查和服务端检查两种,在WebWork2.x中都有很好的支持,首先来分析服务端,服务端的校检类全部来自于com.opensymphony.xwork.validator包,服务端的所有校检工作都是通过一个ValidationInterceptor拦截器来进行拦截的,所以说InterceptorWebWork2.x中的地位就相当于我们心中的“神”,他是用来拯救一切的,有点夸张了,哈哈!

下面请欣赏ValidationInterceptor拦截器的代码

 

public class ValidationInterceptor extends AroundInterceptor {

    protected void after(ActionInvocation dispatcher, String result) throws Exception {

    }

    //获取Action,然后调用ActionValidatorManager来进行检查工作

    protected void before(ActionInvocation invocation) throws Exception {

        Action action = invocation.getAction();

        String context = invocation.getProxy().getActionName();

       

        ActionValidatorManager.validate(action, context);

    }

}

别走开,接着看ActionValidatorManager,由于这个类有点复杂,只做主要的分析,其他则忽略

public class ActionValidatorManager {

   protected static final String VALIDATION_CONFIG_SUFFIX = "-validation.xml";

 

//用于将校检信息缓存起来

    private static final Map validatorCache = Collections.synchronizedMap(new HashMap());

    private static final Map validatorFileCache = Collections.synchronizedMap(new HashMap());

    private static final Log LOG = LogFactory.getLog(ActionValidatorManager.class);

//建立一个DelegatingValidatorContext,用于获取设置资源,如:错误提示信息等

public static void validate(Object object, String context) throws ValidationException {

        ValidatorContext validatorContext = new DelegatingValidatorContext(object);

        validate(object, context, validatorContext);

    }

//

public static void validate(Object object, String context, ValidatorContext validatorContext) throws ValidationException {

//建立一个校检列表

        List validators = getValidators(object.getClass(), context);

        Set shortcircuitedFields = null;

//遍历这个列表

        for (Iterator iterator = validators.iterator(); iterator.hasNext();) {

            Validator validator = (Validator) iterator.next();

            validator.setValidatorContext(validatorContext);

           

        //调用校检类,注意所有的自定义校检类必须从validator接口中实现

validator.validate(object);

            }

           

    }

 

至于客户端校检,由于操作全部来自于com.opensymphony.webwork.validators包,其他的所有校检类都从ScriptValidationAware接口下继承,由于时间的关系我在这里不做分析了,各位如有兴趣,自己去研究吧!

 

其实WebWork2.x里面还有很多相关的细节调用,在此我不能一一描述,各位如果有兴趣的话,也不妨来看看源码。

 

今天就到这里了啊,至于WebWork2.x的标签我就不想看了,不知道是什么原因我就是不太喜欢标签啊,下个Java Web应用我一定用WebWork2.x来进行开发,这么好的一个Framework不用太可惜了啊!

 

Email: zhuam@StudyJava.com

  zhuaming@Gmail.com

 

    Blog: http://blog.csdn.net/zhuam

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值