Struts2提供了stream结果类型,该结果类型就是专门用于支持文件下载功能的。指定stream结果类型时,需要指定一个inputName参数,该参数指定了一个输入流,这个输入流是被下载文件的入口。通过Struts2的文件下载支持,允许系统控制浏览者下载文件的权限,包括实现文件名为非西欧字符的文件下载。
实现文件下载的Action
package com.test.action;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionSupport;
public class FileDownloadAction extends ActionSupport{
//代表下载文件的资源路径
private String inputPath;
//代表下载文件的文件路径
private String contentType;
//代表下载文件的文件名
private String downFileName;
public String getInputPath() {
return inputPath;
}
public void setInputPath(String inputPath) throws Exception {
//处理请求参数的解码
this.inputPath = new String(inputPath.getBytes("iso-8859-1"),"UTF-8");
}
public String getContentType() {
return contentType;
}
public void setContentType(String contentType) {
this.contentType = contentType;
}
public String getDownFileName() {
return downFileName;
}
public void setDownFileName(String downFileName) throws Exception {
this.downFileName = new String(downFileName.getBytes("iso-8859-1"),"UTF-8");
}
/*
* 定义一个参会InputStream的方法,该方法将作为被下载文件的入口
* 且需要配置stream类型结果时指定inputName参数
* inputName参数的值就是方法去掉get前缀。首字母小写的字符串
*/
public InputStream getTargetFile(){
//ServletContext提供getResourceAsStream方法
//返回指定文件对应的输入流
return ServletActionContext.getServletContext().getResourceAsStream(inputPath);
}
}
配置Action配置文件下载的Action需要配置一个类型为stream的结果,该stream类型的结果将使用文件下载作为响应。配置stream类型的结果需要指定以下4个属性:1、inputName:指定被下载文件的入口输入流2、contentType:指定被下载文件的文件类型3、contentDisposition:指定下载文件的文件名4、bufferSize:指定下载文件时的缓冲大小stream结果类型的逻辑视图是返回给客户端的一个输入流,因此无需指定location属性。注:在配置stream类型的结果时,因为无需指定实际显示的物理资源,所以无需指定location属性,只需要指定inputName属性即可,该属性代表被下载文件的入口。struts.xml配置 <!-- 配置处理文件下载的Action -->
<action name="download" class="com.test.action.FileDownloadAction">
<!-- 配置类型为stream的结果 -->
<result name="success" type="stream">
<!-- 指定下载文件的文件类型 -->
<param name="contentType">${contentType}</param>
<!-- 指定由getTargetFile方法返回被下载文件的InputStream -->
<param name="inputName">targetFile</param>
<!-- 指定下载文件的文件名 -->
<param name="contentDisposition">filename="${downFileName}"</param>
<!-- 指定下载文件的缓冲大小 -->
<param name="bufferSize">4096</param>
</result>
</action>
文件下载视图页面<body>
<h3>Struts2的文件下载</h3>
<a href="upload/图片.zip">下载压缩文件</a>
</body>
结果展示: