位置: 编程技术 - 正文

详解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实现文件上传预览

  • 购买土地缴纳的费用
  • 旅游住宿有什么问题
  • 一般纳税人季报怎么申报
  • 减免的企业所得税计入什么科目
  • 发票上税额加不上怎么办
  • 建筑公司包工包料账务处理
  • 固定资产折旧费是产品成本的组成
  • 租赁个人汽车
  • 增值税的核算方式
  • 企业间借款增值税税率
  • 小规模定期定额申报
  • 小规模纳税人核定征收怎么报税
  • 增值税普通发票需要交税吗
  • 企业合同约定调岗不接受辞退没赔偿成立吗
  • 我们4月10日
  • 股票期权所得税率
  • 库存周转天数计算实例
  • 企业是核定征收还是查账征收怎么查
  • 小企业销售费用包括
  • 私户给公户转账多久到账
  • 销项税多了冲销部分的怎么做账
  • win10好几个操作系统
  • 公积金贷款额度查询计算器
  • wifi密码忘记了怎么重新设置密码
  • 建筑业成本核算表格百度网盘
  • windows优化设置
  • 中国各省市区域划分
  • php chm
  • 货物运输业增值税专用发票
  • 纺织企业成本核算方案
  • php json_encode与json_decode详解及实例
  • 回顾2021年作文
  • ChatGPT频频发疯!马斯克警告:AI将毁灭人类
  • 2022年终总结
  • 赔付支出计算公式
  • SQLite数据库安装及基本操作指南
  • 公司没有车加油票怎么做账
  • 营业额包括成本价吗
  • 在SQL Server中使用存储过程的优点包括
  • MSSQL2005在networkservice权限运行附加数据库报(Microsoft SQL Server,错误: 5120)
  • 商品削价的核算
  • 出口货物退货如何入账
  • 申请名称预先核准在哪个网站
  • 应发工资账务处理
  • 资产减值损失科目借方增加还是减少
  • 零税率应税服务出口退税
  • 债券分期付息到期还本的意思
  • 净水设备配件计算方法
  • 预交了增值税款可以退吗
  • 资产减值后折旧怎么算
  • 负数发票怎么开具?
  • 交易性金融资产公允价值变动计入
  • 员工借支备用金属于现金流量的哪类
  • 增值税税控系统专用设备费及技术维护费抵扣
  • 现金日记账和银行存款日记账必须逐日结出余额
  • 未认证的进项税额转出怎么做分录
  • sqlserver中with(nolock)深入分析
  • mysql中的limit用法有哪些(推荐)
  • 利用sql函数生成数据
  • vs2015无法启动程序exe
  • centos7如何设置ssh免密登陆
  • 浏览器登录淘宝安全吗
  • windows8文件夹怎么加密
  • 如何解决焦虑的心理
  • windows7脚本编程和命令行指南
  • 修改etc profile
  • node.js操作文件
  • javascript中怎么创建一个数组
  • Jquery通过ajax请求NodeJS返回json数据实例
  • python怎么获取命令行参数
  • jquery动态添加的元素怎么添加事件
  • 原生js实现promise.all
  • jquery ztree选中节点颜色
  • unity中ngui
  • android开发框架
  • 深入浅出html pdf中文版
  • 个人所得税app怎么更改手机号码
  • 宁夏电子税务局官网登录入口首页
  • 公司注销时注册资金未缴完
  • 允许抵扣和不允许抵扣进项税额的发票种类
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设