现在的位置: 首页 > 综合 > 正文

ExtJS4+SSH 实现Excel导出

2018年01月29日 ⁄ 综合 ⁄ 共 4947字 ⁄ 字号 评论关闭

1.说明

在项目中,我们经常需要导出数据到Excel中。

  前台使用Extjs4.2

  后台使用SSH。

  导出Excel使用Apache的POI组件

POI下载地址:http://poi.apache.org/download.html

POI的Excel导出学习网站:http://poi.apache.org/spreadsheet/quick-guide.html

参考博文:http://blog.csdn.net/gavinloo/article/details/6707828

2. 后台使用 SSH技术 + POI组件 实现excel导出功能

(1)导出功能实现类源码如下:

import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFHeader;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;

/**
 * 利用开源组件POI导出EXCEL文档
 * @param <T> 应用泛型,代表任意一个符合javabean风格的类
 */
public class ExportExcelUtil<T> {
	//excel中sheet的名称
	private String sheetName ="报表内容";
        public ExportExcelUtil() {
		super();
	}
	public ExportExcelUtil(String sheetName) {
		super();
		this.sheetName = sheetName;
	}

    /**
     * 这是一个通用的方法,利用了JAVA的反射机制,可以将放置在JAVA集合中并且符号一定条件的数据以EXCEL 的形式输出到指定IO设备上
     * @param headers
     *            表格属性列名数组
     * @param dataSet
     *            需要显示的数据集合,集合中一定要放置符合javabean风格的类的对象。
     * @param response
     *            与输出设备关联的流对象,可以将EXCEL文档导出到本地文件或者网络中
     */
    @SuppressWarnings("unchecked")
    public void setExcelContents(String[] headers,List<VmReport> dataSet,HttpServletResponse response) {
    	//创建一个新的Excel  
        HSSFWorkbook workBook = new HSSFWorkbook();  
        //创建sheet页  
        HSSFSheet sheet = workBook.createSheet(sheetName);
        // 设置表格默认列宽度为25个字节
        sheet.setDefaultColumnWidth((short) 25);
        //创建header页  
        HSSFHeader header = sheet.getHeader();  
        //设置标题居中  
        header.setCenter("标题");  
        
        // 生成一个样式
        HSSFCellStyle style = workBook.createCellStyle();
        // 设置这些样式
        style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        style.setBorderRight(HSSFCellStyle.BORDER_THIN);
        style.setBorderTop(HSSFCellStyle.BORDER_THIN);
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        // 生成一个字体
        HSSFFont font = workBook.createFont();
        font.setColor(HSSFColor.VIOLET.index);
        font.setFontHeightInPoints((short) 12);
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        // 把字体应用到当前的样式
        style.setFont(font);
        
        // 生成并设置另一个样式
        HSSFCellStyle style2 = workBook.createCellStyle();
        style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);
        style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
        style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        style2.setBorderRight(HSSFCellStyle.BORDER_THIN);
        style2.setBorderTop(HSSFCellStyle.BORDER_THIN);
        style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
        // 生成另一个字体
        HSSFFont font2 = workBook.createFont();
        font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);
        // 把字体应用到当前的样式
        style2.setFont(font2);
        
        //设置第一行为Header  
        HSSFRow row = sheet.createRow(0);  
        //设置第一行的内容和风格
        for(int i=0;i<headers.length;i++){
        	 HSSFCell cell = row.createCell(i);
             cell.setCellStyle(style);
             cell.setCellValue(headers[i]);
        }
        //设置数据
        if(dataSet != null && !dataSet.isEmpty()) {  
            for(int i = 0; i < dataSet.size(); i++) {  
            	VmReport vmport = dataSet.get(i);  
            	//生成一行
                row = sheet.createRow(i + 1);  
                //设置内容和风格
                for(int j=0;j<headers.length;j++){
               	    HSSFCell cell = row.createCell(j);
                    cell.setCellStyle(style2);
                    switch(j){
	                    case 0:
	                    	cell.setCellValue(vmport.getName());
	                    	break;
	                    case 1:
	                    	cell.setCellValue(vmport.getIp());
	                    	break;
	                    case 2:
	                    	cell.setCellValue(vmport.getCpuHighest());
	                    	break;
	                    case 3:
	                    	cell.setCellValue(vmport.getCpuLowest());
	                    	break;
	                    case 4:
	                    	cell.setCellValue(vmport.getMemHighest());
	                    	break;
	                    case 5:
	                    	cell.setCellValue(vmport.getMemLowest());
	                    	break;
	                    }
               }
            }  
        }  
        //通过Response把数据以Excel格式保存  
        response.reset();  
        response.setContentType("application/msexcel;charset=UTF-8");
        //时间格式
        SimpleDateFormat dateformat=new SimpleDateFormat("yyyyMMddHHmmss");
		String time=dateformat.format(new Date());
        try {  
            response.addHeader("Content-Disposition", "attachment;filename=\""  
                    + new String((sheetName+"_" + time+".xls").getBytes("GBK"),  
                            "ISO8859_1") + "\"");  
            OutputStream out = response.getOutputStream();  
            workBook.write(out); 
            out.flush();  
            out.close();  
        } catch (Exception e) {  
            e.printStackTrace();  
        }
    }
    public String getSheetName() {
		return sheetName;
	}
	public void setSheetName(String sheetName) {
		this.sheetName = sheetName;
	}
}

(2)Struts的Action中调用处

public String exportVmInfo() {
		//解析前台传递过来的参数
		//......
		//获取数据库中的数据,此处的dataSet是从数据库中获取的数据。保密起见,未写出。
		List<VmReport> dataSet = null;
		
		String title="报表Sheet的名称....";
		String[] headers = { "名称", "IP地址", "CPU利用率最高", "CPU利用率最低", "内存利用率最高","内存利用率最低"};
		//获取response对象
		HttpServletResponse response = ServletActionContext.getResponse();
		//导出数据至excel中
		ExportExcelUtil<VmReport> exportExcelUtil = new ExportExcelUtil<VmReport>();
		exportExcelUtil.setSheetName(title);
		exportExcelUtil.setExcelContents(headers, dataSet,response);
		//返回null才正确
		return null;
	}

(3)Struts的XML配置文件

<action name="exportVmInfo" class="vmReportAction" method="exportVmInfo">
	 <result type="stream">
	 </result>
</action>

3.前台Extjs调用,实现Excel的导出

window.location.href = 'vmReport/exportVmInfo.do? '+
    	   'startTime='+ startTime +
    	   '&endTime='+ endTime +
    	   '&metricType='+ metricType;  

直接提示给用户是否保存或打开此文档

打开保存后的文件:

抱歉!评论已关闭.