數據導出/下載

来源:http://www.cnblogs.com/javaxiaoxin/archive/2017/08/29/7447469.html
-Advertisement-
Play Games

工具類: ...


工具類:

import java.io.IOException;
import java.net.URLEncoder;

import sun.misc.BASE64Encoder;

public class FileUtils {
        /**
         * 下載文件時,針對不同瀏覽器,進行附件名的編碼
         * 
         * @param filename
         *            下載文件名
         * @param agent
         *            客戶端瀏覽器
         * @return 編碼後的下載附件名
         * @throws IOException
         */
        public static String encodeDownloadFilename(String filename, String agent)
                throws IOException {
            if (agent.contains("Firefox")) { // 火狐瀏覽器
                filename = "=?UTF-8?B?"
                        + new BASE64Encoder().encode(filename.getBytes("utf-8"))
                        + "?=";
                filename = filename.replaceAll("\r\n", "");
            } else { // IE及其他瀏覽器
                filename = URLEncoder.encode(filename, "utf-8");
                filename = filename.replace("+"," ");
            }
            return filename;
        }
}

 

 

 

/**
     * @Description: 查詢所有分區數據,使用附件形式下載
     * @return
     * @throws Exception
     *      
     */
    @Action("subareaAction_exportXls")
    public String exportXls() throws Exception {
        List<SubArea> list = subAreaService.findAll();
        //通過POI將數據寫入excel文件
        HSSFWorkbook workbook = new HSSFWorkbook();  //空白的excel文件
        //創建標簽頁
        HSSFSheet sheet = workbook.createSheet("第一頁分區數據");
        //創建行
        //創建標題行
        HSSFRow headRow = sheet.createRow(0);
        //創建單元格
        headRow.createCell(0).setCellValue("分區編號");
        headRow.createCell(1).setCellValue("關鍵字");
        headRow.createCell(2).setCellValue("輔助關鍵字");
        headRow.createCell(3).setCellValue("起始號");
        headRow.createCell(4).setCellValue("中止號");
        headRow.createCell(5).setCellValue("省市區");
        //創建數據行
        for (SubArea subArea : list) {
            HSSFRow dataRow = sheet.createRow(sheet.getLastRowNum()+1);
            dataRow.createCell(0).setCellValue(subArea.getId());
            dataRow.createCell(1).setCellValue(subArea.getKeyWords());
            dataRow.createCell(2).setCellValue(subArea.getAssistKeyWords());
            dataRow.createCell(3).setCellValue(subArea.getStartNum());
            dataRow.createCell(4).setCellValue(subArea.getEndNum());
            dataRow.createCell(5).setCellValue(subArea.getArea().getName());
        }
        //文件名的中文問題解決(導入工具類):
        String fileName = "分區數據.xls";
        HttpServletRequest request = ServletActionContext.getRequest();
        String agent = request.getHeader("User-Agent");
        fileName = FileUtils.encodeDownloadFilename(fileName, agent);
        
        //文件下載:一個流 兩個頭(文件MIME類型;文件打開方式(瀏覽器內部打開inline;附件形式下載--attachment)
        //從Servers項目下的web.xml中找xls對應的文件類型,比如搜索xls
        HttpServletResponse response = ServletActionContext.getResponse();
        response.setHeader("content-type", "application/vnd.ms-excel");
        response.setHeader("content-disposition", "attachment;fileName="+fileName);
        workbook.write(response.getOutputStream());
        return NONE;
    }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.什麼是閉包(Closure)? 閉包是一個完整的設計功能模塊,可以在代碼中傳遞和使用,類似於Object-C的block(但是還是有區別,下麵會說明)或者其他語言的匿名函數(lambdas)。閉包可以捕獲或者儲存它們所在上下文的常量和變數。在Swift里等價於函數,是一等公民。 閉包有三種形式: ...
  • C++ 簡介 C++是一種靜態類型的、編譯式的、通用的、大小寫敏感的、不規則的變成語言,支持過程化編程、面向對象編程和泛型編程。被認為是一種中級語言。是C的一個超集,事實上任何合法的C程式都是合法的C++程式。 註:使用靜態類型的編程語言是在編譯時執行類型檢查,而不是在運行時執行類型檢查。 面向對象 ...
  • spring boot / cloud (七) 使用@Retryable來進行重處理 前言 什麼時候需要重處理? 在實際工作中,重處理是一個非常常見的場景,比如:發送消息失敗,調用遠程服務失敗,爭搶鎖失敗,等等,這些錯誤可能是因為網路波動造成的,等待過後重處理就能成功.通常來說,會用try/catc ...
  • 首先,在靜態頁面中,添加微信的配置文件,通過js獲取。 <script type="text/javascript"> wx.config({ debug: false, appId: '{$signPackage.appId}', timestamp: '{$signPackage.timesta ...
  • 1 電腦基礎 2 java語言概述 3 第一個java程式 ...
  • 題目鏈接 Problem Description Suppose that you are an admiral of a famous naval troop. Our naval forces have got 21 battleships. There are 6 types of battl ...
  • 本文主要描述3個時間複雜度為n2的排序演算法:冒泡排序、選擇排序、插入排序。 1.冒泡排序:由數組頭部開始,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。每次交換完成後,當前數組最大值就會被放在最後。 傳入參數:a為待排序數組,n為數組長度。 第一個for迴圈,用j的值控制第二個迴圈,即比對數 ...
  • 主要是想給想學習Flask框架的小伙伴一些完整的教程,幫助其更好的學習和掌握Flask框架。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...