采用Spring mvc架构: 
Controller层代码如下

  1. @Controller
  2. public class StudentExportController{
  3. @Autowired
  4. private StudentExportService studentExportService;
  5. @RequestMapping(value = "/excel/export")
  6. public void exportExcel(HttpServletRequest request, HttpServletResponse response)
  7. throws Exception {
  8. List<Student> list = new ArrayList<Student>();
  9. list.add(new Student(1000,"zhangsan","20"));
  10. list.add(new Student(1001,"lisi","23"));
  11. list.add(new Student(1002,"wangwu","25"));
  12. HSSFWorkbook wb = studentExportService.export(list);
  13. response.setContentType("application/vnd.ms-excel");
  14. response.setHeader("Content-disposition", "attachment;filename=student.xls");
  15. OutputStream ouputStream = response.getOutputStream();
  16. wb.write(ouputStream);
  17. ouputStream.flush();
  18. ouputStream.close();
  19. }
  20. }

Service层代码如下:

  1. @Service
  2. public class StudentExportService {
  3. String[] excelHeader = { "Sno", "Name", "Age"};
  4. public HSSFWorkbook export(List<Student> list) {
  5. HSSFWorkbook wb = new HSSFWorkbook();
  6. HSSFSheet sheet = wb.createSheet("Student");
  7. HSSFRow row = sheet.createRow((int) 0);
  8. HSSFCellStyle style = wb.createCellStyle();
  9. style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  10. for (int i = 0; i < excelHeader.length; i++) {
  11. HSSFCell cell = row.createCell(i);
  12. cell.setCellValue(excelHeader[i]);
  13. cell.setCellStyle(style);
  14. sheet.autoSizeColumn(i);
  15. // sheet.SetColumnWidth(i, 100 * 256);
  16. }
  17. for (int i = 0; i < list.size(); i++) {
  18. row = sheet.createRow(i + 1);
  19. Student student = list.get(i);
  20. row.createCell(0).setCellValue(student.getSno());
  21. row.createCell(1).setCellValue(student.getName());
  22. row.createCell(2).setCellValue(student.getAge());
  23. }
  24. return wb;
  25. }
  26. }

前台的js代码如下:

  1. <script>
  2. function exportExcel(){
  3. location.href="excel/export";
  4. <!--这里不能用ajax请求,ajax请求无法弹出下载保存对话框-->
  5. }
  6. </script>
 

Java Web利用POI导出Excel简单例子的更多相关文章

  1. java中使用poi导出excel表格数据并且可以手动修改导出路径

    在我们开发项目中,很多时候会提出这样的需求:将前端的某某数据以excel表格导出,今天就给大家写一个简单的模板. 这里我们选择使用poi导出excel: 第一步:导入需要的jar包到 lib 文件夹下

  2. struts2中利用POI导出Excel文档并下载

    1.项目组负责人让我实现这个接口,因为以前做过类似的,中间并没有遇到什么太困难的事情.其他不说,先上代码: package com.tydic.eshop.action.feedback; impor ...

  3. 利用poi导出Excel

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

  4. java 通过Apache poi导出excel代码demo实例

    package com.zuidaima.excel.util; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutput ...

  5. JAVAWeb SSH框架 利用POI 导出EXCEL,弹出保存框

    导入包这一些不多说,直接贴出关键代码,JSP只要点一个Action链接就行. poi包我是用:poi-3.11-20141221.jar 亲测有效: 效果: Action 类代码: private I ...

  6. Java web项目JXl导出excel,(从eclipse上移动到tomact服务器上,之路径更改)

    我用的是jxl导出excel,比较简单,最开始我是固定路径不能选择,很局限,后来改了,而且固定路径当把项目放在服务器上时,路径不可行. 在网上各位大神的帮助成功设置响应头,并且可选保存路径. 1.前端 ...

  7. java中使用 POI导出excel表格的简单实现

    大概流程分7步: 1.创建工作簿 --> 2.创建sheet表 --> 3.创建row行(建议使用循环) --> 4.用row行逐一创建单元格(建议使用循环) --> 5.单元 ...

  8. java web利用mvc结构实现简单聊天室功能

    简单聊天室采用各种内部对象不适用数据库实现. 一个聊天室要实现的基本功能是:         1.用户登录进入聊天室, 2.用户发言 3.用户可以看见别人发言 刚才算是简单的需求分析了,现在就应该是进 ...

  9. Spring Boot利用poi导出Excel

    至于poi的用法就不多说了,网上多得很,但是发现spring boot结合poi的就不多了,而且大多也有各种各样的问题. public class ExcelData implements Seria ...

随机推荐

  1. IOS设计模式-简单工厂

    为什么 “简单工厂原理” 叫简单工厂,因为这个工厂类不是抽象类,而是实体类,工厂本身就是一个具体的对象. 写一个例子演示简单工厂模式: >>>>>>>> ...

  2. [Nginx][HttpUpstreamModule]翻译负载均衡

    英文原文地址:http://nginx.org/en/docs/http/ngx_http_upstream_module.html 大纲: 示例 指令 嵌入变量 ngx_http_upstream_ ...

  3. Java部分总结图片版(已经加上原图链接下载!!!)

    Java基础知识图片版(原图下载链接)

  4. 深入理解java虚拟机(1)------内存区域与内存溢出

    在C++领域,关于C++的内存存储,结构等等,有一本书:深度探索C++对象模型,讲解的非常透彻. 而Java确把这一工作交给了虚拟机来处理. 我们首先来看看关于内存的问题. 1.问题: 1)java ...

  5. Effective Java 06 Eliminate obsolete object references

    NOTE Nulling out object references should be the exception rather than the norm. Another common sour ...

  6. Effective Java 49 Prefer primitive types to boxed primitives

    No. Primitives Boxed Primitives 1 Have their own values Have identities distinct from their values 2 ...

  7. spring中的 classpath* 存在可移植性问题

    classpath* 的可移植性问题,许多人都应该遇到过了.下面就是一个例子(使用的是spring4.1.5和mybatis3.2.8): <bean id="sqlSessionFa ...

  8. PL/SQL之--流程控制语句

    一.简介 像编程语言一样,oracle PL/SQL也有自己的流程控制语句.通过流程控制语句,我们可以在PL/SQL中实现一下比较复杂的业务逻辑操作.而无需到程序中去控制,在一定程度上提高了效率,这也 ...

  9. Windows下MongoDB安装与设置

    最近在研究传奇已久的MongoDB,遇到很多问题,将整理好的Windows下的MongoDB整体到连接过程分享给大家,也留给自己. 第一步:下载http://www.mongodb.org/downl ...

  10. MCS51系列单片机实用技术部分课件