struts2文件上传.doc_第1页
struts2文件上传.doc_第2页
struts2文件上传.doc_第3页
struts2文件上传.doc_第4页
struts2文件上传.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

引用 Struts2文件上传和下载2008-08-28 20:17:47|分类: Struts2 |标签: |字号大中小订阅 引用wanglei19850713 的 Struts2文件上传和下载1. 文件上传的原理:表单元素的enctype属性指定的是表单数据的编码方式,该属性有3个值:1) application/x-www-form-urlencoded:这是默认编码方式,它只处理表单域里的value属性值,采用这种编码方式的表单会将表单域的值处理成URL编码方式。2) multipart/form-data:这种编码方式的表单会以二进制流的方式来处理表单数据,这种编码方式会把文件域指定文件的内容也封装到请求参数里。3) text/plain:这种方式主要适用于直接通过表单发送邮件的方式。文件上传是web应用经常用到的一个知识。原理是,通过为表单元素设置enctype=multipart/form-data属性,让表单提交的数据以二进制编码的方式提交,在接收此请求的Servlet中用二进制流来获取内容,就可以取得上传文件的内容,从而实现文件的上传。在Java领域中,有两个常用的文件上传项目:一个是Apache组织Jakarta的Common-FileUpload组件(/fileupload/),另一个是Oreilly组织的COS框架(/cos/)。利用这两个框架都能很方便的实现文件的上传。2. Struts2的文件上传:Struts2并未提供自己的请求解析器,也就是就Struts2不会自己去处理multipart/form-data的请求,它需要调用其他请求解析器,将HTTP请求中的表单域解析出来。但Struts2在原有的上传解析器基础上做了进一步封装,更进一步简化了文件上传。Struts2默认使用的是Jakarta的Common-FileUpload框架来上传文件,因此,要在web应用中增加两个Jar文件:commons-fileupload-1.2.jar和commons-io-1.3.1.jar。它在原上传框架上做了进一步封装,简化了文件上传的代码实现,取消了不同上传框架上的编程差异。如果要改成其它的文件上传框架,可以修改struts.multipart.parser常量的值为cos/pell,默认值是jakata。并在classpath中增加相应上传组件的类库。2.1. 步骤一:创建带上传表单域的页面 Struts2 File Upload 文件标题: 选择文件: 此页面特殊之处只是把表单的enctype属性设置为multipart/form-data。2.2. 步骤二:创建处理上传请求的Action类package org.qiujy.web.struts2;import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.InputStream;import java.io.OutputStream;import org.apache.struts2.ServletActionContext;import com.opensymphony.xwork2.ActionSupport;/*处理文件上传的Action类*authorqiujy*version1.0*/publicclass FileUploadAction extends ActionSupport privatestaticfinalintBUFFER_SIZE = 16 * 1024; / 文件标题 private String title; / 上传文件域对象 private File upload; / 上传文件名 private String uploadFileName; / 上传文件类型 private String uploadContentType; / 保存文件的目录路径(通过依赖注入) private String savePath; /以下省略getter和setter. /自己封装的一个把源文件对象复制成目标文件对象 privatestaticvoid copy(File src, File dst) InputStream in = null; OutputStream out = null; try in = new BufferedInputStream(new FileInputStream(src), BUFFER_SIZE); out = new BufferedOutputStream(new FileOutputStream(dst), BUFFER_SIZE); byte buffer = newbyteBUFFER_SIZE; int len = 0; while (len = in.read(buffer) 0) out.write(buffer, 0, len); catch (Exception e) e.printStackTrace(); finally if (null != in) try in.close(); catch (IOException e) e.printStackTrace(); if (null != out) try out.close(); catch (IOException e) e.printStackTrace(); Override public String execute() throws Exception /根据服务器的文件保存地址和原文件名创建目录文件全路径 String dstPath = ServletActionContext.getServletContext() .getRealPath(this.getSavePath() + + this.getUploadFileName(); System.out.println(上传的文件的类型:+ this.getUploadContentType(); File dstFile = new File(dstPath); copy(this.upload, dstFile); returnSUCCESS; color:black | 上面这个Action类中,提供了title和upload两个属性来分别对应页面的两个表单域属性,用来封装表单域的请求参数。 但是,值得注意的是,此Action中还有两个属性:uploadFileName和uploadContentType,这两个属性分别用于封装上传文件的文件名、文件类型。这是Struts2设计的独到之处:Strut2的Action类直接通过File类型属性直接封装了上传文件的文件内容,但这个File属性无法获取上传文件的文件名和文件类型,所以Struts2就直接将文件域中包含的上传文件名和文件类型的信息封装到uploadFileName和uploadContentType属性中,也就是说Struts2针对表单中名为xxx的文件域,在对应的Action类中使用3个属性来封装该文件域信息: l类型为File的xxx属性:用来封装页面文件域对应的文件内容。 l类型为String的xxxFileName属性:用来封装该文件域对应的文件的文件名。 l类型为String的xxxContentType属性:用来封装该文件域应用的文件的文件类型。 另外,在这个Action类中还有一个savePath属性,它的值是通过配置文件来动态设置的,这也是Strut2设计中的一个依赖注入特性的使用。 2.3. 步骤三:配置 struts.xml文件: | /upload /showupload.jsp 在这个文件中跟以前配置唯一不同的是给action配置了一个元素,用来为该Action的savePath属性动态注入值。web.xml中的配置跟以前的应用一样。说明一点:好多网络文章说Struts2上传时要在web.xml中配置一个名为ActionContextUp的过滤器,说是有一些莫名的错误,可是是我用了Struts2新版本2.0.9GA版,测了n次,没出现什么问题,所以没配置。2.4. 运行调试:运行前要在根目录下创建一个名为upload的文件夹,用来存放上传后的文件。上传结果:3. 文件类型及错误输出:Struts2提供了一个文件上传的拦截器(名为fileUpload),通过配置这个拦截器能轻松地实现文件类型的过滤。在上例中,若要配置上传的文件只能是一些普通的图片文件格式:image/bmp、image/png、image/gif、image/jpeg、image/jpg等,则可在struts.xml文件中按如下方式配置: * *image/bmp,image/png,image/gif,image/jpeg,image/jpg ,image/x-png, image/pjpeg 102400 /upload /index.jsp /showupload.jsp 如果上传文件失败,系统返回到input对应的页面,要在input对应的页面输出文件过滤失败信息,可以在input对应的页面中增加 来显示错误信息。运行调试:结果: 显然,这样的提示不太友好,应用使用国际化信息。在国际化资源文件中添加如下三句:#更改上传文件类型不允许的提示信息struts.messages.error.content.type.not.allowed=文件上传失败:你要上传的文件类型不允许#更改上传文件太大的提示信息struts.messages.error.file.too.large=文件上传失败:你要上传的文件太大#文件上传其它错误信息struts.messages.error.uploading=文件上传失败:发生内部错误 以上是我在网上找的一个比较详细的Struts2文件上传的解说但在实际中还要注意一些问题1.如果用到了spring的方法注入的话一定不要忘了加 scope=prototype这样每次访问action时,都会新建一个action,否则的话,会记录上传action留下的记录,出现意想不到的错误。2.上传时出现的错误信息是放在request范围内的如果出现错误返回的input页面不是上传文件的form页面那么可以把错误信息提取出来String error = this.getFieldErrors().get(file).toString();(file指struts2 file标签里 name的名字)放在request,session。范围内然后在input指定的页面显示错误信息。3.文件大小和类型的限制是通过Struts2拦截器实现的你只需要在上传的action中做如下配置就可以application/octet-stream,application/x-zip-compressed,image/bmp,image/png,image/gif,image/jpeg,image/jpg,image/x-png,image/pjpeg5242880但是有一点要注意Struts2默认文件上传最大为2M即便你设置了5242880当上传的文件大于2M时候也会出错的这时要设置另外一个常量要让他的value设置的比你限定上传最大值要大一点。以上是文件上传要注意的几点其实文件上传看起来比较难实际上比较简单,而文件下载就有点麻烦了遇到了很恼人的编码和乱码问题。1.文件下载的action和普通的action查不多仅仅是该Action需要提供一个返回InputStream流的方法public InputStream getInputStream() throws ExceptionAttachment attachment=attachmentManager.get(Long.valueOf(attachmentId); File downFile=new File(attachment.getFilePath(); InputStream inStream = new FileInputStream(downFile);return inStream; 有一点要注意struts2提供了一个ServletActionContext.getServletContext().getResourceAsStream(filePath);方法根据路径返回输入流,但是这个方法和servletContext有关,当你把下载的文件放在项目的根目录中才可以否则会出错的,最保险的办法就是根据文件路径找到这个文件然后在转化成输入流返回。配置:2048/输入流缓冲的大小inputStream/inputStream和getInputStream()是对应的2.编码,当文件名是中文时String downFileName = new String(downFileName.getBytes(ISO8859-1), utf-8);getResponse().setHeader(Content-Disposition,att

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论