快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

WebWork2源码分析续二


下面我们再来分析另一个拦截器的实现ModelDrivenInterceptor,首先说说他的设计目的,我们知道在Struts中通常有一个ActionFormBean他是用来封装哀求数据的,在WebWork2.x中这一功能得到了进一步的发挥,他可以实现两中Action驱动模式,他们都是信息携带者.



Property-Driven



Model-Driven




 


最通俗的解释就是, Property-Driven通过属性来贯穿整个MVC,而Model-Driven就是通过Model对象来贯穿整个MVC.




 


他们的存在方法: Model-Drive就是独立的一个类,而Property-Driven则必须依附于你自定义的Action类




 


假如我们用Model-Drive方法,那么就必须在配置文件中添加ModelDrivenInterceptor拦截器,由这个拦截器向我们的Model Bean中传递值,且你的Action中 也必须实现ModelDriven接口,用于获取该Model Bean,下面来看看这个拦截器的详细实现,来做进一步的分析,代码如下:




 


public class ModelDrivenInterceptor extends AroundInterceptor {



    //~ Methods ////////////////////////////////////////////////////////////////



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



    protected void before(ActionInvocation invocation) throws Exception {



        Action action = invocation.getAction();



        if (action instanceof ModelDriven) {



//判定该Action是否实现了ModelDriven接口,假如实现了这个ModelDriven接口,他将向这个Action所对应的Model传递信息



            ModelDriven modelDriven = (ModelDriven) action;



            OgnlValueStack stack = invocation.getStack();




 


// 用于获取Action中的Model Bean,并压入OgnlValueStack



            stack.push(modelDriven.getModel());



        }



    }



}



关于OgnlValueStack 的详细信息请参考 http://www.ognl.org




 


从上面的这个public String intercept(ActionInvocation invocation) 方式中我们可以看出所有的拦截器都是通过ActionInvocation来执行调度的,我们可以称DefaultActionInvocation为XWork1.x的调度器,说的这里我想各位对WebWork2.x的拦截器也有了一个大概的了解.




 


既然DefaultActionInvocation是xWork1.x的调度器,不分析他是说不过去的,接下来我们分析ActionInvocation的实现者DefaultActionInvocation的源码,已窥其毕竟




 



 


由于之前也分析过DefaultActionInvocation的一些代码, 下面则节选部分还没有分析的代码来完成简要的分析




 


public class DefaultActionInvocation implements ActionInvocation {



//在这里Result是一个接口,而ActionChainResult是他的一个实现,他的目的是用于处理Action Chain的,在这里对Action Chain做以下说明:



通常一个Action执行完毕,要么是返回表单,要么返回另外一个Action,来继承执行, 假如返回了Action则就形成了Action Chain  动作链,然后继承执行这个新的Action,直到返回一个non-chain结果



public Result getResult() throws Exception {



        Result returnResult = result;



        // If we\\\'ve chained to other Actions, we need to find the last result



        while (returnResult instanceof ActionChainResult) {



            ActionProxy aProxy = ((ActionChainResult) returnResult).getProxy();



            if (aProxy != null) {



                Result proxyResult = aProxy.getInvocation().getResult();



                if ((proxyResult != null) && (aProxy.getExecuteResult())) {



                    returnResult = proxyResult;



                } else { break; }



            } else { break; }



        }



        return returnResult;



    }



//返回Stack



    public OgnlValueStack getStack() {



        return stack;



    }







    //下面的方式我就不在赘述了,我想大家就是看名称也应该可以了解一二,假如有什么疑问,请参考前面的分析



protected void createAction() {   



    // load action



    try {



            action = ObjectFactory.getObjectFactory().buildAction(proxy.getConfig());







}



protected String invokeAction(Action action, ActionConfig actionConfig) throws Exception {



    if (proxy.getConfig().getMethodName() == null) {



            return getAction().execute();







}



}






返回类别: 教程
上一教程: java中的易混问题收集
下一教程: Good Java Style: Part 2

您可以阅读与"WebWork2源码分析续二"相关的教程:
· WebWork2源码分析续三
· WebWork2源码分析续一
· WebWork2源码分析
· JUnit源码分析(三)
· JUnit源码分析(二)
    微笑服务 优质保证 索取样品