@H_502_0@本文主要通过三个方面给大家介绍webwork action调用相关知识,三个方面分别是:
@H_502_0@1.这部分框架类关系 @H_502_0@2.Webwork 获取和包装 web 参数 @H_502_0@3.DefaultActionProxyFactory、DefaultActionProxy、DefaultActionInvocation @H_502_0@一路走来,终于要开始 webwork 核心业务类的总结,webwork 通过对客户端传递的 web 参数重新包装,进行执行业务 Action 类,并反馈执行结果,本篇源码分析对应下图 WebWork 框架流转图中红色框的地方。
404,e);
} catch (Exception e) {
log.error("Could not execute action",500,e);
}
}
@H_502_0@•首先 ServiceAction 调用了createContextMap 创建Action 上下文(extraContext)。 它将JavaServlet 相关的对象进行包装,放入extraContext Map对象里。
@H_502_0@•接着检查 上一个请求中是否有可用的值堆栈,如果有就放入extraContext 这个Map 对象里,供本次请求使用 。
@H_502_0@•ActionContext(com.opensymphony.xwork.ActionContext)是Action执行时的上下文,上下文 可以看作是一个容器(其实我们这里的容器就是一个Map 而已),它存放的是Action 在执行时需要用到的对象。
@H_502_0@• ServletActionContext ( com.opensymphony.webwork. ServletActionContext),这个类直接继承了ActionContext,它提供了直接与JavaServlet 相关象访问的功能。
@H_502_0@•OgnlValueStack主要的功能是通过表达式语言来存取对象的属性。
@H_502_0@3.DefaultActionProxyFactory、DefaultActionProxy、DefaultActionInvocation
@H_502_0@前戏终于做完了,Action 调用的三兄弟要登场进行最重要的操作了,就是下面这三句代码,与Webwork 学习之路(五)请求跳转前 xwork.xml 的读取代码有非常相似的写法和设计:
0)) {
message = LocalizedTextUtil.findDefaultText("xwork.exception.missing-package-action",Locale.getDefault(),new String[] {
namespace,actionName });
} else {
message = LocalizedTextUtil.findDefaultText("xwork.exception.missing-action",new String[] {
actionName });
}
throw new ConfigurationException(message);
}
prepare();
}
@H_502_0@•将传入的名称空间、 Action 的名字等参数赋予本地变量,接着通过 ConfigurationManager 获得当前请求的 Action 的配置信息[这里在5中已经描述过]。接着调用自身的 prepare 方法创建一个 ActionInvocation 对象赋予自身变量 invocation。在之后的 execute 方法中通过操纵invocation 来实现我们自己写的Action 的调用。