注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

放飞自由

年轻人,如果三年的时间里,没有任何想法,他这一生,就基本这个样子,没有多大改变。

 
 
 

日志

 
 

Struts2导出Excel(poi)步骤及问题汇总(二) 下载  

2013-06-17 23:41:51|  分类: JAVA后台 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
该部分内容是在《Struts2导出Excel步骤及问题汇总(一)》的前提下完成的,该部分内容可以参考百度经验Struts2导出Excel步骤及问题汇总(一) poi分页  或者 本博客中 Struts2导出Excel步骤及问题汇总(一) poi分页

Action中处理,包含下载中文文件乱码、为空的问题。
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.util.Date;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;

import com.monkey.base.action.BaseAction;
import com.monkey.service.ProductCardService;
import com.monkey.util.DateUtils;
import com.monkey.vo.ProductCard;
import com.opensymphony.xwork2.ModelDriven;

public class ProductCardAction2 extends BaseAction implements
ModelDriven<ProductCard> {

private static final long serialVersionUID = 6658682414884709427L;

@Autowired
private ProductCardService productCardService;

private ProductCard pc;

private String fileName; // 下载文件名称
private InputStream excelFile; // 下载文件流

public ProductCard getModel() {
if (null == pc)
pc = new ProductCard();
return pc;
}

public String download() throws Exception {
HSSFWorkbook workbook = xxx(); // 这个为调用service层返回的HSSFWorkbook对象
ByteArrayOutputStream output = new ByteArrayOutputStream();
workbook.write(output);
byte[] ba = output.toByteArray();
excelFile = new ByteArrayInputStream(ba);
output.flush();
output.close();
return "excel";
}

public String getDownloadFileName() {
return fileName;
}

public ProductCard getPc() {
return pc;
}

public void setPc(ProductCard pc) {
this.pc = pc;
}

/**
* 返回类型为"中文名字-20130612231234.xls"
*
* @return
*/
public String getFileName() throws Exception {
String tempName = "中文名字"
+ "-"
+ DateUtils.formatDate(DateUtils.LONG_DATE_PATTERN_PLAIN,
new Date()) + ".xls";

fileName = new String(tempName.getBytes(), "ISO8859-1");
System.out.println(fileName);
return fileName;
}

public void setFileName(String fileName) {
this.fileName = fileName;
}

public InputStream getExcelFile() {
return excelFile;
}

public void setExcelFile(InputStream excelFile) {
this.excelFile = excelFile;
}

}


struts.xml下载项配置说明:

<!-- 下载导出excle -->
<result name="excel" type="stream">  
   <param name="contentType">application/vnd.ms-excel,charset=ISO8859-1</param>
   <param name="contentDisposition">attachment;filename="${fileName}"</param>  
   <param name="bufferSize">4096</param>
   <param name="inputName">excelFile</param>  
</result>


注意事项:
  1. 请注意文中加粗部分内容
  2. 中文解决办法汇总:

代码部分:

String tempName = "中文名字"+"-" 
               + DateUtils.formatDate(DateUtils.LONG_DATE_PATTERN_PLAIN, new Date())
               + ".xls";
       
fileName = new String(tempName.getBytes(), "ISO8859-1");


配置文件部分:

<param name="contentType">application/vnd.ms-excel,charset=ISO8859-1</param>


原文地址:Struts2导出Excel(poi)步骤及问题汇总(二) 下载
  评论这张
 
阅读(663)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017