位置: 编程技术 - 正文

详解Webwork中Action 调用的方法(activate webstorm)

编辑:rootadmin

推荐整理分享详解Webwork中Action 调用的方法(activate webstorm),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:web中的action,web active,web activex,activate webstorm,webworker react,activate webstorm,web annotation,web activex,内容如对您有帮助,希望把文章链接给更多的朋友!

本文主要通过三个方面给大家介绍webwork action调用相关知识,三个方面分别是:

1.这部分框架类关系

2.Webwork 获取和包装 web 参数

3.DefaultActionProxyFactory、DefaultActionProxy、DefaultActionInvocation

一路走来,终于要开始 webwork 核心业务类的总结,webwork 通过对客户端传递的 web 参数重新包装,进行执行业务 Action 类,并反馈执行结果,本篇源码分析对应下图 WebWork 框架流转图中红色框的地方。

1.这部分框架类关系

2.Webwork 获取和包装 web 参数

&#;每个Web 框架或多或少的对 Web 请求参数的包装,用来拿来方便自己使用,当然webwork 也不例外。&#;Webwork 每次响应请求的入口方法:

&#;接受 request 、response 参数,并对 request 参数进行封装,这次封装主要是针对多媒体请求进行的特殊处理,例如项目中的文件上传请求,导出各种类型文件等...

&#;包装完 request 之后,service 方法调用 ServletDispatche.serviceAction() 方法,并调用 getApplicationMap、getSessionMap、getRequestMap、 getParameterMap、getActionName、getNameSpace 6 个方法开始了Action 业务逻辑调用前的前戏。

&#;getNameSpace 方法用来获得一个Action所属的名称空间,例如 : "/my/MyAction.action"则返回"/my",具体实现如下:

&#;getActionName 返回请求的Action的名字,例如:"MyAction.action"则返回"MyAction",具体实现如下:

&#; getRequestMap 方法返回一个包含请求中所有属性的Map,具体实现类是 RequestMap,具体代码如下:

详解Webwork中Action 调用的方法(activate webstorm)

&#;getParameterMap 方法返回一个包含请求中所有参数的Map,具体代码如下:

&#;getSessionMap 方法返回一个包含 session 中所有属性的 Map,具体实现类是 SessionMap,具体代码如下:

&#;getApplicationMap 方法返回一个包含 Application 中所有属性的Map,具体实现类 是ApplicationMap,具体代码如下:

&#;WebWork之所以要把request 的属性、参数,session 中的属性,Application 中的属性封装成 Map,仅仅是为了自己使用方便。

&#;首先 ServiceAction 调用了createContextMap 创建Action 上下文(extraContext)。 它将JavaServlet 相关的对象进行包装,放入extraContext Map对象里。

&#;接着检查 上一个请求中是否有可用的值堆栈,如果有就放入extraContext 这个Map 对象里,供本次请求使用 。

&#;ActionContext(com.opensymphony.xwork.ActionContext)是Action执行时的上下文,上下文 可以看作是一个容器(其实我们这里的容器就是一个Map 而已),它存放的是Action 在执行时需要用到的对象。

&#; ServletActionContext ( com.opensymphony.webwork. ServletActionContext),这个类直接继承了ActionContext,它提供了直接与JavaServlet 相关象访问的功能。

&#;OgnlValueStack主要的功能是通过表达式语言来存取对象的属性。

3.DefaultActionProxyFactory、DefaultActionProxy、DefaultActionInvocation

前戏终于做完了,Action 调用的三兄弟要登场进行最重要的操作了,就是下面这三句代码,与Webwork 学习之路(五)请求跳转前 xwork.xml 的读取代码有非常相似的写法和设计:

proxy.execute(); &#;通过由前面获得的namespace、actionName、extraContext 创建调用代理 ActonProxy 实例,这里也就是 DefaultActionProxy,之后调用 了 ActionProxy.execute 方法来执行我们逻辑Action.execute。

&#;ActionProxy是一个接口,ActionProxyFactory则是一个抽象类,默认情况下它们是通过 DefaultActionProxy和DefaultActionProxyFactory来完成操作的。

&#;在 ActionProxyFactory 中有一个静态变量 factory ,它指向的是一个 DefaultActionProxyFactory 实例,代码如下:

&#; DefaultActionProxyFactory 的 createActionProxy 方法返回了 DefaultActionProxy 实例。

&#;将传入的名称空间、 Action 的名字等参数赋予本地变量,接着通过 ConfigurationManager 获得当前请求的 Action 的配置信息[这里在5中已经描述过]。接着调用自身的 prepare 方法创建一个 ActionInvocation 对象赋予自身变量 invocation。在之后的 execute 方法中通过操纵invocation 来实现我们自己写的Action 的调用。

以上所示是针对Webwork中Action 调用 的相关知识,希望对大家有所帮助。

js+html5操作sqlite数据库的方法 本文实例讲述了js+html5操作sqlite数据库的方法。分享给大家供大家参考,具体如下://copyrightbylanxyoulanxyou[at]gmail.comvarlanxDB=function(dbname){vardb=openDatabase(dbna

JavaScript File API实现文件上传预览 一、概述以往对于基于浏览器的应用而言,访问本地文件都是一件头疼的事情。虽然伴随着Web2.0应用技术的不断发展,JavaScript正在扮演越来越重要的角

javascript自定义滚动条实现代码 在工作中经常会遇到内容会超出固定的一个范围,超出的内容一般会使用到滚动条来滚动显示。但是用浏览器默认的滚动条经常被产品经理鄙视,可是

标签: activate webstorm

本文链接地址:https://www.jiuchutong.com/biancheng/381712.html 转载请保留说明!

上一篇:JavaScript File API文件上传预览

下一篇:JavaScript File API实现文件上传预览

  • 哪些收据可以入帐
  • 工会经费的应税项是什么
  • 什么是抄报税成功
  • 怎么算印花税计算器
  • 车船税保险公司会不会多收
  • 一张记账凭证写两个分录
  • 与企业日常无关的政府补服属于利得吗
  • 以前年度损益调整影响本年利润
  • 个人所得税能否跨年度
  • 企业的主管部门承担什么责任
  • 记账凭证按其适用的交易和事项分类可以分为
  • 供应商提供财务报表
  • 应收票据质押会计处理
  • 增值税期末留抵税额的账务处理
  • 健身房属于什么经营类别
  • 外籍员工家属入境
  • windows 10纯净版
  • 腾讯电脑管家上的steam可以吗
  • 一年内的待摊费用可以一次性进入成本吗
  • 经营性支付与非经营性支付
  • 琼斯的大海怪
  • 代扣代缴个税手续费返还政策
  • 无形资产的界定及特点
  • 自由职业者如何交五险一金
  • 银行存款的利息收入计入什么科目
  • php deprecated
  • 用人单位未为劳动者缴纳社会保险费
  • echarts柱形图
  • 税前扣除项目什么意思
  • 甲方如何规避合同责任
  • ts中如何定义一个数组
  • 公司买的公文包会计怎么做
  • 2023新版拳击航母
  • 前后端分离项目部署到服务器
  • 减资资产负债表怎么填
  • discuz如何关闭站点
  • 车票如何抵扣增值税税率
  • 赔偿客户款应该怎么记账
  • java8 (jdk 1.8) 新特性——Lambda
  • sqlserver2019查看表
  • 购买固定资产未入账
  • 理财产品分红和收益
  • 股东买房能在银行贷款吗
  • 劳动合同和劳务合同可以一起签吗
  • sql2008附加数据库错误3456
  • 福利费可以抵扣所得税吗
  • 银行贷款每个银行一样吗
  • 社保下个月扣款
  • 购礼品送客户分账务处理怎么做
  • 应交税金的负数重分类
  • 结转固定资产清理科目
  • 单位之间借款还款怎么写
  • 税审报告一定要税所主任签吗
  • 建账的要点及应注意的问题
  • 什么叫商业会计
  • Windows下安装爱思助手V8
  • win8安全中心在哪
  • win108080端口怎么打开
  • ubuntu16.04 ssh连接不上
  • win7系统桌面图标变大了怎样恢复
  • 无法安装windows xp
  • 文件fwpkc1nt.sys
  • 如何设置访问共享文件夹
  • 远程电脑屏幕桌面图标什么都没有了
  • win10registry
  • 怎样解决windows照片查看器无法显示此图片
  • win7空间不足c盘
  • react 技巧
  • webpack 主题切换
  • python 二叉树
  • JavaScript function函数种类详解
  • python数据连接
  • jquery返回顶部
  • 自己搭配电脑
  • 如何找回电子税务局企业密码
  • 研发费用加计扣除2022政策
  • 重庆电子税务局网页版登录
  • 拿了全额发票必须按时办理房产证吗
  • 消费税的征收范围是如何规定的
  • 社保在线审核
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设