struts2.1.6教程九、文件上传下载(了解)

时间:2021-08-01 12:38:50

首先建立struts2UpDownLoad项目,搭建好struts2基本的开发环境。

  1. 上传实例

步骤一:upload.jsp代码如下:

<s:form action="upload" method="post" enctype="multipart/form-data">
<s:file name="file" label="上传的头像(格式:jpg,gif,bmp)"></s:file>
<s:submit value="上传"/> <s:reset value="取消"/>
</s:form>

注意:在form标签中我们用到了enctype实体,这是上传时必须用到得。
步骤二,建立struts.xml。对upload.action的配置如下:

<action name="upload" class="com.asm.UploadAction">
<param name="savePath">img</param>
<result>/upSuc.jsp</result>
<result name="input">upload.jsp</result>
<interceptor-ref name="defaultStack">
<param name="fileUpload.maximumSize">1024*1024</param>
<param name="fileUpload.allowedTypes">
image/bmp,image/pjpeg,image/gif
</param>
</interceptor-ref>
</action>

在这里唯一需要说明的是<interceptor-ref>下的参数问题,在以前如果要为某个特定的拦截器传递参数需要在<interceptor>下配置pararm参数,在此处我们用.形式来配置fileUpload拦截器的参数。这用做即可以保证默认的拦截器栈起作用,也可以向fileUpload拦截器传递参数。第一个参数是限制上传图片的大小(除了可以这样限制图片大小,也可以配置一个常量的方法来限制上传文件的大小,配置的内容为:<constant name="struts.multipart.maxSize" value="文件大小"/>),第二个参数是限制上传图片的格式只能为bmp,pjpeg,gif关于这些参数可以参看fileupload拦截器对应类的api文档。

另还需注意:在action下的“<param name="savePath">img</param>”代码可以为UploadAction的savePath字段传递值,这样作的好处是在项目正式发布后,我们可以通过修改struts.xml中的配置来灵活给savePath赋值。而如果直接在java源代码中初始化savePath的值,在项目运行后就不能简单修改。这种用法主要是为了给客户提供一个灵活可配的特定初始化方式。

步骤三、编写UploadAction,主要代码如下:

package com.asm;
public class UploadAction extends ActionSupport {
private String savePath;
private File file;
private String fileFileName;
private String fileContentType; public String execute() throws Exception {
String path=ServletActionContext.getServletContext().getRealPath(savePath);
String savaFileName=path+"\\"+fileFileName;
//System.out.println(savaFileName); BufferedInputStream bis=null;
BufferedOutputStream bos=null;
try{
bis=new BufferedInputStream(new FileInputStream(file));
bos=new BufferedOutputStream(new FileOutputStream(savaFileName)); byte []buf=new byte[(int) file.length()];
int len=0;
while((len=bis.read(buf))!=-1){
bos.write(buf,0,len);
}}catch(Exception e){
e.printStackTrace();
}finally{
if(bis!=null)
bis.close();
if(bos!=null)
bos.close();
}
return SUCCESS;
}
...省略以上四个字段的get/set方法
}

说明:其实上传的难点就是在此action的处理上。首先是从配置文件中读取文件的保存路径,然后联合fileFileName(命名规则是上传的文件对应的字段名+FileName,如果要得到上传文件的类型,固定的写法应是上传的文件对应的字段名+ContentType,比如这里应为fileContentType)来确定完整的保存路径,并最终为创建BufferedOutputStream作准备。BufferedInputStream是通过前台upload.jsp页面传递的file构建。特别要注意处理流,如果书写不当可能会使上传文件循环写入,使得硬盘容量不够。还要注意对流的关闭问题。 补充:关于文件的操作可以使用commons-io.jar包的FileUtils类下的copyFile方法来进行文件的拷贝,比如这里调用copyFile方法(file,要保存的目录)

上传成功后,upSuc.jsp的主要内容如下:

<body>
<h4>上传成功,以下是你刚上传的图片:</h4>
<img src="<%=request.getContextPath() %>/<s:property value="savePath+'/'+fileFileName"/>"> <br>
保存路径为:<s:property value="savePath+'/'+fileFileName"/>
</body>

说明:当上传成功后,会显示上传的图片。

扩展实例:如果想上传多个文件,可以在Action中使用File[] files来接受上传的文件(jsp中对应的上传文件的参数均应为files)。对应的上传文件的名字,使用String[] fileFileName。然后循环files数组保存File文件对象。

2.下载实例

下载页面的doload.jsp的主要代码如下:

<a href="download.action?downloadName=img/a.bmp">下载图片</a><br>
<a href="download.action?downloadName=img/music.rar">下载千千静听</a><br>

对应的download action配置如下:

<action name="download" class="com.asm.DownloadAction">
<result name="success" type="stream">
<param name="inputName">targetFile</param>
<param name="contentType">
image/bmp,application/x-zip-compressed
</param>
</result>
</action>

说明:type类型指明了结果集为流类型,并且为流类型结果集配置了参数,inputName指定流的来源,这里来源为targetFile,所以在下面的Action中有getTargetFile方法, contentType指明下载时的文件类型。

DownloadAction的主要代码如下:

package com.asm;
public class DownloadAction extends ActionSupport {
private String downloadName;
public String execute() throws Exception {
return SUCCESS;
} public InputStream getTargetFile(){
return ServletActionContext.getServletContext().getResourceAsStream(downloadName);
} public void setDownloadName(String downloadName) {
this.downloadName = downloadName;
}
}

说明:下载实例在此略作了解,具体可以借助apache组织提供的上传下载开源项目理解。