SpringMVC POI导出EXCEL

   当今,J2EE企业级开发中SpringMVC无疑占据着举足轻重的地位,而POI又很好的支持了Excel操作,这两者的结合很好的支持了企业级报表系统的开发,废话不多说了,直接进入主题

1、首先,在项目的lib目录下导入SpringMVC相关的Jar包,同时,导入

2、创建entity对象:

package com.entity;

import java.io.Serializable;

public class PersonEntity implements Serializable {

	private static final long serialVersionUID = 6916427667499861702L;
	private Integer id;
	private String name;
	private Integer age;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Integer getAge() {
		return age;
	}
	public void setAge(Integer age) {
		this.age = age;
	}

}

3、创建dao接口和对应的实现类:

package com.dao;

import java.util.List;

import com.entity.PersonEntity;

public interface PersonEntityDao {
	List<PersonEntity> getList();
}

dao接口的实现类

package com.dao.impl;
import com.dao.PersonEntityService;
import java.util.List;

import com.entity.PersonEntity;
@Repository
public class PersonEntityDaoImpl implements PersonEntityDao {

	@Override
	public List<PersonEntity> getList() {
		//操作数据库
		return null;
	}

}

  4、建立service接口和对应的实现类

package com.service;

import java.util.List;

import com.entity.PersonEntity;

public interface PersonEntityService {
	List<PersonEntity> getList();
}

  service实现类

package com.service.impl;

import java.util.List;
import com.dao.PersonEntityDao;

import com.entity.PersonEntity;
import com.service.PersonEntityService;
@Service
public class PersonEntityServiceImpl implements PersonEntityService {
	@Resource
        private PersonEntityDao personDao;
	@Override
	public List<PersonEntity> getList() {
		// TODO Auto-generated method stub
		return personDao.getList();
	}

}

5、创建处理下载中文名称Excel的工具类(防止生成的Excel名称中有中文而出现乱码的现象)

package com.poi;
import java.net.URLEncoder;

import javax.mail.internet.MimeUtility;
import javax.servlet.http.HttpServletRequest;

import com.sinever.util.StringUtils;

public class MyUtils {
	/**
     * 设置下载文件中文件的名称
     *
     * @param filename
     * @param request
     * @return
     */
    public static String encodeFilename(String filename, HttpServletRequest request) {
      /**
       * 获取客户端浏览器和操作系统信息
       * 在IE浏览器中得到的是:User-Agent=Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; Maxthon; Alexa Toolbar)
       * 在Firefox中得到的是:User-Agent=Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.7.10) Gecko/20050717 Firefox/1.0.6
       */
      String agent = request.getHeader("USER-AGENT");
      try {
        if ((agent != null) && (-1 != agent.indexOf("MSIE"))) {
          String newFileName = URLEncoder.encode(filename, "UTF-8");
          newFileName = StringUtils.replace(newFileName, "+", "%20");
          if (newFileName.length() > 150) {
            newFileName = new String(filename.getBytes("GB2312"), "ISO8859-1");
            newFileName = StringUtils.replace(newFileName, " ", "%20");
          }
          return newFileName;
        }
        if ((agent != null) && (-1 != agent.indexOf("Mozilla")))
          return MimeUtility.encodeText(filename, "UTF-8", "B");  

        return filename;
      } catch (Exception ex) {
        return filename;
      }
    }
}

6、创建ViewExcel类,此类要继承AbstractExcelView类,覆写AbstractExcelView类中的buildExcelDocument方法

package com.sinever.poi;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import com.entity.PersonEntity;
public class ViewExcel extends AbstractExcelView {
	@Override
	protected void buildExcelDocument(Map<String, Object> obj,
			HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response)
			throws Exception {
        // map的key,在对应的controller中设置
         List<PersonEntity> list = (List<PersonEntity>) obj.get("list");
         HSSFSheet sheet = workbook.createSheet("list");
        sheet.setDefaultColumnWidth((short) 12);
        HSSFCell cell = getCell(sheet, 0, 0);
        setText(cell, "ID");
        cell = getCell(sheet, 0, 1);
        setText(cell, "姓名");
        cell = getCell(sheet, 0, 2);
        setText(cell, "年龄");

        for (short i = 0; i < list.size(); i++) {
        	HSSFRow sheetRow = sheet.createRow(i+1);
        	PersonEntity entity = list.get(i);
        	sheetRow.createCell(0).setCellValue(entity.getId());
            sheetRow.createCell(1).setCellValue(entity.getName());
            sheetRow.createCell(2).setCellValue(entity.getAge());
        }
       //设置下载时客户端Excel的名称
        String filename = new SimpleDateFormat("yyyy-MM-dd").format(new Date())+".xls";
      //处理中文文件名
        filename = MyUtils.encodeFilename(filename, request);
        response.setContentType("application/vnd.ms-excel");
        response.setHeader("Content-disposition", "attachment;filename=" + filename);
        OutputStream ouputStream = response.getOutputStream();
        workbook.write(ouputStream);
        ouputStream.flush();
        ouputStream.close();
	}
}

7、创建相应的controller类

package com.controller;

import java.util.List;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

import com.rmi.entity.PersonEntity;
import com.service.PersonEntityService;
import com.sinever.poi.ViewExcel;

@Controller
@RequestMapping(value="/person")
public class PersonEntityController {
	@Resourse
	private PersonEntityService personEntityService;

	@RequestMapping(value ="/export",method=RequestMethod.GET)
	public ModelAndView export(ModelMap model, HttpServletRequest request){
		List<PersonEntity> list = personEntityService.getList()
		ViewExcel viewExcel = new ViewExcel();
               //将查询出的list集合存入ModelMap 对象中,此时的key就是ViewExcel类中Map所对应的key
                model.put("list", list);
                return new ModelAndView(viewExcel, model);
	}
}

至此,整个过程结束,效果如下图:

时间: 2024-11-10 08:19:47

SpringMVC POI导出EXCEL的相关文章

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

在我们开发项目中,很多时候会提出这样的需求:将前端的某某数据以excel表格导出,今天就给大家写一个简单的模板. 这里我们选择使用poi导出excel: 第一步:导入需要的jar包到 lib 文件夹下 jar包下载路径:http://download.csdn.net/download/pumpkin09/7077011 第二步:添加poi导出工具类 1 package com.yjd.admin.util; 2 3 import java.io.IOException; 4 import ja

使用Apache POI导出Excel小结--导出XLS格式文档

使用Apache POI导出Excel小结 关于使用Apache POI导出Excel我大概会分三篇文章去写 使用Apache POI导出Excel小结--导出XLS格式文档 使用Apache POI导出Excel小结--导出XLSX格式文档 使用Apache POI导出Excel--大数量导出 导出XLS格式文档 做企业应用项目难免会有数据导出到Excel的需求,最近在使用其,并对导出Excel封装成工具类开放出来供大家参考.关于Apache POI Excel基本的概念与操作我在这里就不啰嗦

POI导出EXCEL经典实现

在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF,我这里就用两篇文章分别给大家介绍下.(注意,我们这里说的数据导出可不是数据库中的数据导出!么误会啦^_^) 呵呵,首先我们来导出EXCEL格式的文件吧.现在主流的操作Excel文件的开源工具有很多,用得比较多的就是Apache的POI及JExcelAPI.这里我们用Apache POI!我们先去Apach

POI导出EXCEL经典实现(转)

http://www.cnblogs.com/xwdreamer/archive/2011/07/20/2296975.html 1.Apache POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能. .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 POI 的功能. 2.POI结构 HSSF - 提供读写Microsoft Excel XLS格式档案的功能.XS

JAVA关于POI导出Excel内存溢出的解决方案

JAVA关于POI导出Excel内存溢出的解决方案 在我们使用JAVA开发过程中,经常要导出查询获得的数据,这些数据一般情况下都是以Excel存储的,因此我们在导出数据的时候要使用JAVA的POI库,其主要是对各种windows平台的数据格式进行操作,在这里,我们是对Excel操作. 生成Excel的过程原理是这样的,首先,我们对数据库进行查询,获取相应的结果集,一般是list集合,然后生成Workbook对象,根据生成的Workbook对象获取sheet对象,根据此sheet对象获取Row对象

用POI导出excel时,较长的数字不想被自动变为科学计数法的解决方式(转)

做过很多次导出excel了.都碰到一个问题,内容里如果包含一个比较长的数字,比如订单号“2546541656596”,excel会自动变成科学计数法... 弄过好几次都没有解决,最近又要导出excel了,下决心一定要找到解决办法 自己在excel里测试过,较长的数字,都会自动变成科学计数法,除非我们把单元格格式设置成“文本型” 哈哈,似乎找到了思路:用poi先把单元格设置成“文本型”就可以了把. 从文档里找到了这个方法HSSFCell.setCellType(int type),怎么看这个方法都

poi导出excel

Java使用poi组件导出excel报表,能导出excel报表的还可以使用jxl组件,但jxl想对于poi功能有限,jxl应该不能载excel插入浮动层图片,poi能很好的实现输出excel各种功能,介绍poi导出excel功能实现案例,算比较常用的功能实现以及导出excel需要注意的地方,采用的是poi-3.8-20120326.jar,poi-ooxml-3.8-20120326.jar,poi-scratchpad-3.8-20120326.jar 输出表格 poi输出excel最基本是输

Java POI 导出EXCEL经典实现 Java导出Excel弹出下载框

在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF,我这里就用两篇文章分别给大家介绍下.(注意,我们这里说的数据导出可不是数据库中的数据导出!么误会啦^_^) 呵呵,首先我们来导出EXCEL格式的文件吧.现在主流的操作Excel文件的开源工具有很多,用得比较多的就是Apache的POI及JExcelAPI.这里我们用Apache POI!我们先去Apach

使用poi导出Excel

很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告.有时,一个应用程序甚至希望将Excel文件作为输入数据. 常见的java Excel  API Java Aspose Cells Java Aspose Cells 是一种纯粹的Java授权的Excel API,开发和供应商Aspose发布.这个API的最新版本是8.1.2,发布于2014年7月,是一个丰富而厚重的API(普通Java类和AWT类的组合)设计,可以读.写和操纵电子表格Excel的组件.此API常见用