位置: 编程技术 - 正文

Webwork 实现文件上传下载代码详解(web docs)

编辑:rootadmin

推荐整理分享Webwork 实现文件上传下载代码详解(web docs),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:web文件用什么程序打开,web写文件,web-work,web-work,web写文件,web怎么运行文件,web写文件,webwiew实现,内容如对您有帮助,希望把文章链接给更多的朋友!

本文主要从三个方面给大家介绍webwork文件上传下载知识,包括以下三个方面:

1. 包装 Request 请求2. 获取文件上传的解析类 3. 项目实战配置和使用

Web上传和下载应该是很普遍的一个需求,无论是小型网站还是大并发访问的交易网站。WebWork 当然也提供了很友好的拦截器来实现对文件的上传,让我们可以专注与业务逻辑的设计和实现,在实现上传和下载时顺便关注了下框架上传下载的实现。

1. 包装 Request 请求

&#;每次客户端请求 Action 时,都会调用 WebWork 调度类 ServletDispatcher.service()方法。

具体过程请参照:详解Webwork中Action 调用的方法

先来看看 wrapRequest 方法做了什么:

&#; 首先判断了传进来的 request 是不是已经被封装好的 MultiPartRequestWrapper,如果是就直接返回。&#; 否则再判断 request 的头信息里面的 Content­Type 是不是多类型参数 (multipart/form­data)的请求,如果是就把 request 包装成 WebWork 自己的 MultiPartRequestWrapper 类型,该类型继承HttpServletRequestWrapper 。

MultiPartRequest.isMultiPart() 方法实现如下:

&#;在 webwork.properties 里面配置文件的临时存储目录、还有最大上传大小,其实就是在这个时候起到作用的。&#;创建 MultiPartRequestWrapper 对象的时候传入的参数是由 getSaveDir() 和 getMaxSize() 方 法 获 得 的 。&#;在方法里会查找配置里面的 webwork.multipart.saveDir、 webwork.multipart.maxSize 属性,找到则使用该属性指定的临时目录和上传的最大内容,没找到就使用环境的临时目录。

具体实现如下:

2. 获取文件上传的解析类

Webwork 实现文件上传下载代码详解(web docs)

再来看一下 MultiPartRequestWrapper 的构造函数使如何包装 request 的:

&#; 首先它判断了传入的 request 是不是 MultiPartRequest 抽象类的子类,如果是就直接把自身的 MultiPartRequest 类型的变量引用 request。

&#; 否则读取 WebWork 配置 的webwork.multipart.parser 属性,该属性决定 Webwork 内部用什么实现文件上传。 如果没有指定,则默认使用 PellMultiPartRequest 的实现。

&#;找到配置的类后,WebWork 通过 Java 反射创建该类的实例。所有支持的类都是从 MultiPartRequest 继承而来,创建该实例后向上转型,并赋予 MultiPartRequestWrapper 的成员multi。

&#; WebWork 的文件上传封装了几种通用的 FileUpload lib,并不是自己实现的。

&#;它包括了pell,cos,apache common 三种实现,WebWork 对这三个包进行封装,提供了一 个通用的访问接口 MultiPartRequest,细节实现分别是 PellMultiPartRequest、 CosMultiPartRequest 、JakartaMultiPartRequest 。

&#; jakarta 支持多个文件使用同一个HTTP参数名。如果直接使用 WebWork 的 FileUpload 拦截器,推荐使用pell,因为当你上传中文文件名称的文件的时候,只有pell 包会正确的获得中文文件名称,apache common会将文件名称改为xxx.tmp这样的文件名,而cos会乱码, 因此我们唯一的选择只有 pell。

&#;cos 的功能比较强大,WebWork 的封装却使它丧失了很多的功能,cos 需要设置 request 的character encoding。WebWork的封装没有设置,所以就导致了cos的乱码问题,当然如果你单独 使用cos,则会避免此类问题。

3. 项目实战配置和使用

&#; 配置文件

action 配置:

&#;前端使用比较稳定、功能比较强大的 Ajaxupload这里就不多说了,有官方网址:jQuery AjaxUpload 上传图片代码

&#;通过对 Webwork 上传请求的封装和解析类的获取,所有的前戏都已经准备妥当,上传拦截器里面具体实现如下:

&#;首先判断当前请求是否为 包含多媒体请求,如果是则记录日志,并执行 Action。&#;然后判断在文件上传过程 MultiPartRequestWrapper 是否含有错误,将错误信息,返回给客户端,不在继续调用 Action。&#;如果上面的判断条件都没有进行,开始遍历 MultiPartRequestWrapper 中的上传文件的参数,并将其中的文件名、文件内容类型放入Action 参数 map 中,供后面的业务类进行操作。&#;在 WebWork 的 fileupload 拦截器功能中,它提供的 File只 是一个临时文件,Action 执行之后就会被自动删除,你必须在 Action中自己处理文件的存储问题,或者写到服务器的某个目录,或者保存到数据库中。如果你准备写到服务器的某个目录下面的话,你必须自己面临着处理文件同名的问题,但是实际上cos包已经提供了 文件重名的自动重命名规则。

通过以上代码给大家介绍了Webwork 实现文件上传下载的相关知识,希望对大家有所帮助。

javascript绘制漂亮的心型线效果完整实例 本文实例讲述了javascript绘制漂亮的心型线效果实现方法。分享给大家供大家参考,具体如下:运行效果截图如下:具体代码如下:!DOCTYPEHTMLhtmlheadmetachar

JavaScript File API文件上传预览 对于基于浏览器的应用而言,访问本地文件都是一件头疼的事情,通常我们能做的仅仅是使用inputtype="file"标签来上传文件。实现过程是:选取文件的时

详解Webwork中Action 调用的方法 本文主要通过三个方面给大家介绍webworkaction调用相关知识,三个方面分别是:1.这部分框架类关系2.Webwork获取和包装web参数3.DefaultActionProxyFactory、DefaultA

标签: web docs

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

上一篇:javascript自动切换焦点控制效果完整实例(js自动切换图片效果)

下一篇:javascript绘制漂亮的心型线效果完整实例(javascript如何绘制曲线)

  • 企业税号还未开户
  • 转让费和押金的区别
  • 金税四期对小规模纳税人
  • 出口货物离岸价格
  • 固定资产二级科目取消原因
  • 进项税额留抵科目
  • 食堂收支情况
  • 代扣代缴增值税纳税义务发生时间
  • 餐费专票认证了怎么办
  • 事业编年底
  • 定期定额个体工商户个人所得税
  • 孵化器 怎么赚钱
  • 发票升额需要什么条件
  • 其他收益等于什么
  • 转出多交增值税会计科目
  • 工会经费的会计分录2023
  • 工资和薪金是一回事吗
  • 销售部门品种多怎么说
  • 报销冲销借款
  • 公司代缴社保公司吃亏吗
  • rapapp.exe - rapapp是什么进程 有何作用
  • 专柜公司货什么意思
  • 电脑前面板耳机没声音怎么设置bios
  • 坏账损失税务处理
  • 马纳斯古盐田气候特征
  • 运动目标检测算法
  • 废旧物资回收企业所得税优惠政策
  • vue3响应式丢失
  • php获取文件内容的函数
  • 细说php
  • 资产为什么等于成本
  • mysql跨库join
  • HTML 事件参考手册
  • 利润表净利润等于未分配利润吗
  • 个人申请给公司账户转账
  • 增值税申报系统登录密码
  • 如何查询去年企业所得税
  • 小规模纳税人免增值税的账务处理
  • python for循环遍历
  • 大气污染物排放2020标准
  • 退休职工能否扣医保
  • 零申报对企业有什么影响
  • mysql三种安装方式
  • 企业取得的财政性资金
  • 赠送的商品如何开发票
  • 境外中资企业再投资
  • 年中未分配利润
  • 企业进项构成比例
  • 代开发票预缴税款的比例是多少呢?
  • 一般纳税人月销售额10万以下
  • 金税盘清卡怎么操作视频
  • 合伙企业所得税率
  • 工程公司本月没发工资
  • 财付通入帐中
  • 会计利润是利润加暂时性差异吗为什么
  • 工业企业固定资产投资
  • Mysql主从同步Last_IO_Errno:1236错误解决方法
  • sqlserver数据库怎么导出
  • 这张图告诉我们什么道理
  • Mac Chrome打开HTTPS证书错误问题解决方法
  • win8如何设置
  • win7系统无法更改账户名称
  • jsp分页显示
  • cocos2dx小游戏
  • webuploader使用教程
  • python+django
  • jquery 表单
  • 基于android开发
  • 深入理解新发展理念
  • 开发Blog整理
  • js tojsonstring
  • javascript面向对象编程指南 pdf
  • 退伍军人买车需要摇号吗
  • 广州市税务局长
  • 大连地税局发票怎么开
  • 土地使用税一般谁交
  • 职业年金利息计入哪个科目里面
  • 48岁了还有必要上环吗
  • 税务负责人
  • 审计的起源和发展史
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设