package com.zcloud.util; import com.zcloud.entity.PageData; import org.apache.poi.hssf.usermodel.*; import org.apache.poi.ss.usermodel.HorizontalAlignment; import org.apache.poi.ss.usermodel.VerticalAlignment; import org.apache.poi.ss.usermodel.Workbook; import org.springframework.web.servlet.view.document.AbstractXlsView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Date; import java.util.List; import java.util.Map; /** * 说明:导出到EXCEL(图片压缩) * 作者:luoxiaobao * 官网:www.qdkjchina.com */ public class HiddenExcelCompressImg extends AbstractXlsView{ @Override protected void buildExcelDocument(Map model, Workbook workbook, HttpServletRequest request, HttpServletResponse response) throws Exception { // TODO Auto-generated method stub // String proPath = PathUtil.getProjectpath(); String beji = Const.HTTPFILEURL; Date date = new Date(); String filename = DateUtil.date2Str(date, "yyyyMMddHHmmss"); response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment;filename="+filename+".xls"); HSSFSheet sheet; HSSFWorkbook book = (HSSFWorkbook) workbook; sheet = book.createSheet("sheet1"); List titles = (List) model.get("titles"); int len = titles.size(); HSSFCellStyle headerStyle = book.createCellStyle(); //标题样式 headerStyle.setAlignment(HorizontalAlignment.CENTER); headerStyle.setVerticalAlignment(VerticalAlignment.CENTER); HSSFFont headerFont = book.createFont(); //标题字体 headerFont.setBold(true); headerFont.setFontHeightInPoints((short)11); headerStyle.setFont(headerFont); short height=25*20; HSSFRow row = sheet.createRow(0); if(len>250) { len = 250; } for(int i=0; i250) { row.createCell(i).setCellValue(title.substring(0, 250)); }else { row.createCell(i).setCellValue(title); } } sheet.getRow(0).setHeight(height); HSSFCellStyle contentStyle = book.createCellStyle(); //内容样式 HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); contentStyle.setAlignment(HorizontalAlignment.CENTER); List varList = (List) model.get("varList"); int varCount = varList.size(); for(int i=0; i 0) { // zos.write(buf, 0, length); // } // zos.closeEntry(); // } catch (Exception e) { // e.printStackTrace(); // } finally { // // in.close(); // zos.close(); // } // excel.delete(); // response.setHeader("Content-Disposition", "attachment; filename=\"" + filename+".zip" + "\""); // response.setContentType("application/octet-stream;charset=UTF-8"); // OutputStream os = response.getOutputStream(); // os.write(bos.toByteArray()); // os.close(); } }