• 深入struts2.0(六)--ActionProxy类


    1.1     ActionProxy接口以及实现

    ActionProxy在struts框架中发挥着很关键的数据。

    通过webwork和xwork交互关系图能够看出。它是action和xwork中间的一层。 正由于ActionProxy的存在导致Action调用更加简洁。

    接下来我们一起研究下这个核心类。

    1.1.1       ActionProxy接口方法


    图 3.3.1 ActionProxy接口主要方法图

    ActionConfig getConfig();该方法主要是获得创建ActionProxy类的action配置信息。getExecuteResult()方法就是推断运行后action后是否运行result. getInvocation()获得与ActionProxy相关联的ActionInvocation.

    1.1.2       ActionProxy接口实现类


    图 3.3.2 ActionProxy接口实现类图

    依据命名就知道defaultActionProxy是默认的actionProxy代理。

    对于MockActionProxy这个类笔者也不太明确。这个类在struts代码中也没实用。在API中也没有说明,依据字面意思。就是对ActionProxy一个简单实现。

    1.1.3       DefaultActionProxy实现类

    在dispatcher类中我们能够看到例如以下代码:

    proxy.execute();

       

     表示将由ActionProxy代理类来运行action,全部action的主要运行方法就是actionProxy中的execute.

        public String execute() throws Exception {

            ActionContext nestedContext = ActionContext.getContext();

            ActionContext.setContext(invocation.getInvocationContext());

     

            String retCode = null;

     

            String profileKey = "execute: ";

            try {

                UtilTimerStack.push(profileKey);

     

                retCode = invocation.invoke();

            } finally {

                if (cleanupContext) {

                    ActionContext.setContext(nestedContext);

                }

                UtilTimerStack.pop(profileKey);

            }

     

            return retCode;

        }

     

    图 3.3.3 ActionProxy接口execute方法

    首先把InvocationContext设置到ActionContext上下文中。然后调用InvocationContext中的invoke方法运行。

  • 相关阅读:
    t=20点击发送pingback
    Hibernate 序列生成主键
    oracle创建存储过程
    mysql允许某ip访问
    ORACLE用户解锁
    oracle查询锁表
    oracle杀掉执行的死循环存储过程
    oracle以逗号分隔查询结果列表
    查询oracle的session数
    oracle存储过程-获取错误信息
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10679043.html
  • Copyright © 2020-2023  润新知