日期:2014-05-17  浏览次数:21014 次

Struts下使用type="stream"配置action,文件下载时报错getOutputStream() has already been called
Struts下使用type="stream"配置action,文件下载时报错getOutputStream() has already been called 
在网上找了一下解决办法
http://www.cnblogs.com/zenger1025/archive/2013/02/05/2893219.html
但是它这里使用的不是type="stream"配置action,所以他这里可以使用return null
但是我使用的是type="stream"配置action,所以不能return null
请问这样应该怎么解决呢?
或者如果说不用type="stream"配置action,那么应该怎么配置呢?html页面又如何实现呢?


以下是我的struts配置:
<action name="download" class="Actions.FileActions"> 
            <result name="success" type="stream"> 
                <param name="contentType">application/octet-stream</param> 
                <param name="contentDisposition">attachment;filename="${fileFileName}"</param> 
                <param name="inputName">downloadFile</param> 
                <param name="bufferSize">4096</param> 
            </result> 
            <result name="input">/index.jsp</result> 
        </action> 


action是这样写的:
public InputStream getDownloadFile() {  
// System.out.println("downloadfile...");
File_UploadDaoImpl uploadDaoIpml = null;
DownloadHistoryDaoImpl historyDaoImpl = null;
conn = DBCPpool.getConnection();
uploadDaoIpml = new File_UploadDaoImpl(conn);
historyDaoImpl = new DownloadHistoryDaoImpl(conn);
File_Upload file = null;
try {
file = uploadDaoIpml.selectFileById(Integer.parseInt(id));
fileFileName = file.getFileName() + file.getType();
fileFileName = new String(fileFileName.getBytes(),"iso8859-1");

//登记下载记录
//从session中获取当前用户
HttpServletRequest request = ServletActionContext.getRequest();
HttpSession session = request.getSession();
User user = (User) session.getAttribute("user");

DownloadHistory downHistory = new DownloadHistory();
downHistory.setUserName(user.getLoginName());
downHistory.setFileId(file.getId());
downHistory.setFileName(file.getFileName());
downHistory.setFileType(file.getType());

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String downTime = sdf.format(new Date());
downHistory.setDownTime(downTime);

historyDaoImpl.addHistory(downHistory);
} catch (NumberFormatException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} finally{
if(conn!=null)
try {
conn.close();
} catch (SQLException e) {