zoukankan      html  css  js  c++  java
  • 深入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方法运行。

查看全文
  • 相关阅读:
    @RenderBody()和@RenderSection()
    C# async await 死锁问题总结
    [小技巧]你真的了解C#中的Math.Round么?
    ASP.NET MVC
    api接口返回动态的json格式?我太难了,尝试一下 linq to json
    bootstrap-table表头固定,表内容不对齐的问题
    Windows下Nginx反向代理
    Windows下Nginx的启动停止等基本操作命令详解
    Asp.NET websocket,Asp.NET MVC 使用 SignalR 实时更新前端页面数据
    Asp.NET websocket,Asp.NET MVC 使用 SignalR 实现推送功能一(Hubs 在线聊天室)
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10679043.html
  • Copyright © 2011-2022 走看看