1. 程式人生 > >Spring mvc 下Excel匯出

Spring mvc 下Excel匯出

參考了網上資料,實現Spring mvc 下Excel匯出 ,如有更好方法請大家拍磚

1.新建類繼承AbstractExcelView

Java程式碼  收藏程式碼
  1. import java.io.OutputStream;  
  2. import java.util.Map;  
  3. import javacommon.util.MyUtils;  
  4. import javax.servlet.http.HttpServletRequest;  
  5. import javax.servlet.http.HttpServletResponse;  
  6. import org.apache.poi.hssf.usermodel.HSSFCell;  
  7. import org.apache.poi.hssf.usermodel.HSSFCellStyle;  
  8. import org.apache.poi.hssf.usermodel.HSSFRow;  
  9. import org.apache.poi.hssf.usermodel.HSSFSheet;  
  10. import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
  11. import org.springframework.web.servlet.view.document.AbstractExcelView;  
  12. public class ViewExcel extends
     AbstractExcelView {  
  13.     @Override  
  14.     protected void buildExcelDocument(Map<String, Object> obj,  
  15.             HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response)  
  16.             throws Exception {  
  17.         HSSFSheet sheet = workbook.createSheet("list");    
  18.         sheet.setDefaultColumnWidth((short
    12);    
  19.         HSSFCell cell = getCell(sheet, 00);    
  20.         setText(cell, "Spring Excel test");    
  21.         HSSFCellStyle dateStyle = workbook.createCellStyle();    
  22.         //dateStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("mm/dd/yyyy"));    
  23.         cell = getCell(sheet, 10);    
  24.         cell.setCellValue("日期:2008-10-23");    
  25.         //cell.setCellStyle(dateStyle);    
  26.         getCell(sheet, 20).setCellValue("測試1");    
  27.         getCell(sheet, 21).setCellValue("測試2");  
  28.         HSSFRow sheetRow = sheet.createRow(3);    
  29.         for (short i = 0; i < 10; i++) {    
  30.             sheetRow.createCell(i).setCellValue(i * 10);    
  31.         }    
  32.         String filename = "測試.xls";//設定下載時客戶端Excel的名稱     
  33.         filename = MyUtils.encodeFilename(filename, request);//處理中文檔名  
  34.         response.setContentType("application/vnd.ms-excel");     
  35.         response.setHeader("Content-disposition""attachment;filename=" + filename);     
  36.         OutputStream ouputStream = response.getOutputStream();     
  37.         workbook.write(ouputStream);     
  38.         ouputStream.flush();     
  39.         ouputStream.close();     
  40.     }  
  41. }  

處理中文檔名的方法:

Java程式碼  收藏程式碼
  1. /**  
  2.      * 設定下載檔案中檔案的名稱  
  3.      *   
  4.      * @param filename  
  5.      * @param request  
  6.      * @return  
  7.      */    
  8.     public static String encodeFilename(String filename, HttpServletRequest request) {    
  9.       /**  
  10.        * 獲取客戶端瀏覽器和作業系統資訊  
  11.        * 在IE瀏覽器中得到的是:User-Agent=Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; Maxthon; Alexa Toolbar)  
  12.        * 在Firefox中得到的是:User-Agent=Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.7.10) Gecko/20050717 Firefox/1.0.6  
  13.        */    
  14.       String agent = request.getHeader("USER-AGENT");    
  15.       try {    
  16.         if ((agent != null) && (-1 != agent.indexOf("MSIE"))) {    
  17.           String newFileName = URLEncoder.encode(filename, "UTF-8");    
  18.           newFileName = StringUtils.replace(newFileName, "+""%20");    
  19.           if (newFileName.length() > 150) {    
  20.             newFileName = new String(filename.getBytes("GB2312"), "ISO8859-1");    
  21.             newFileName = StringUtils.replace(newFileName, " ""%20");    
  22.           }    
  23.           return newFileName;    
  24.         }    
  25.         if ((agent != null) && (-1 != agent.indexOf("Mozilla")))    
  26.           return MimeUtility.encodeText(filename, "UTF-8""B");    
  27.         return filename;    
  28.       } catch (Exception ex) {    
  29.         return filename;    
  30.       }    
  31.     }   

2接下來在你的下載 Controller裡面返回ModelAndView 即可

Java程式碼  收藏程式碼
  1. /** 
  2.     * 匯出Excel 
  3.     * @param model 
  4.     * @param projectId 
  5.     * @param request 
  6.     * @return 
  7.     */  
  8.    @RequestMapping(value="/dcExcel",method=RequestMethod.GET)  
  9.     public ModelAndView toDcExcel(ModelMap model, HttpServletRequest request){  
  10.        List list = new ArrayList();  //測試資料沒有用到  
  11.        Map map = new HashMap();    
  12.        list.add("test1");    
  13.        list.add("test2");    
  14.        map.put("list", list);    
  15.        ViewExcel viewExcel = new ViewExcel();    
  16.        return new ModelAndView(viewExcel, model);   
  17.    }  

程式碼很簡單,只實現下載,關於Excel 格式資料方面請參考 poi 框架