当今,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
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
getList() {
//操作数据库
return null;
}
}
4、建立service接口和对应的实现类
package com.service;
import java.util.List;
import com.entity.PersonEntity;
public interface PersonEntityService {
List
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
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.u