springmvc生成Excel并且返回给客户端

springmvc生成Excel并且返回给客户端

1、首先是springmvc生成文件。

2、生成excel。==》这个可以参考我的apache POI EXCEL生成专题。点击打开链接

好了,下面是代码:
[java]  view plain  copy
  1. package enht.soft.newhotelstn.controller;  
  2.   
  3. import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
  4. import org.apache.poi.ss.usermodel.Cell;  
  5. import org.apache.poi.ss.usermodel.Row;  
  6. import org.apache.poi.ss.usermodel.Sheet;  
  7. import org.apache.poi.ss.usermodel.Workbook;  
  8. import org.apache.poi.ss.util.CellReference;  
  9. import org.springframework.http.HttpHeaders;  
  10. import org.springframework.http.HttpStatus;  
  11. import org.springframework.http.MediaType;  
  12. import org.springframework.http.ResponseEntity;  
  13. import org.springframework.stereotype.Controller;  
  14. import org.springframework.web.bind.annotation.RequestMapping;  
  15. import org.springframework.web.bind.annotation.RequestMethod;  
  16.   
  17. import java.io.*;  
  18.   
  19. /** 
  20.  * Created by Administrator on 2016-09-02. 
  21.  */  
  22. @Controller  
  23. @RequestMapping(value = "/downloadFile", method = {RequestMethod.GET, RequestMethod.POST})  
  24. public class FileDownLoad {  
  25.     @RequestMapping("download")  
  26.     public ResponseEntity<byte[]> download() throws IOException {  
  27.   
  28.         Workbook wb = new HSSFWorkbook();  
  29.         Sheet sh = wb.createSheet();  
  30.         for (int rownum = 0; rownum < 50; rownum++) {  
  31.             Row row = sh.createRow(rownum);  
  32.             for (int cellnum = 0; cellnum < 30; cellnum++) {  
  33.                 Cell cell = row.createCell(cellnum);  
  34.                 CellReference cr = new CellReference(cell);  
  35.                 String address = cr.formatAsString();  
  36.                 cell.setCellValue(address + "row:" + cr.getRow() +" col:" +cr.getRow());  
  37.             }  
  38.         }  
  39.   
  40.         ByteArrayOutputStream out = new ByteArrayOutputStream();  
  41.         try {  
  42.             wb.write(out);  
  43.         } catch (IOException e) {  
  44.             // TODO Auto-generated catch block  
  45.             e.printStackTrace();  
  46.         }  
  47.         HttpHeaders headers = new HttpHeaders();  
  48.         String fileName = new String("测试.xls".getBytes("UTF-8"), "iso-8859-1");//为了解决中文名称乱码问题  
  49.         headers.setContentDispositionFormData("attachment", fileName);  
  50.         headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);  
  51.         ResponseEntity<byte[]> filebyte = new ResponseEntity<byte[]>(out.toByteArray(),headers, HttpStatus.CREATED);  
  52.         try {  
  53.             out.close();  
  54.         } catch (IOException e) {  
  55.             // TODO Auto-generated catch block  
  56.             e.printStackTrace();  
  57.         }  
  58.         return filebyte;  
  59.     }  
  60. }  

3、需要的jar包

4、运行后的结果:

5、如果运行的时候发现比较慢的话,可以把数据弄的少一些。

原文转载:http://blog.csdn.net/wild46cat/article/details/52413884
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值