java導出服務器已經配置好的excel模板


采用springboot的項目架構。

目錄結構

 

1. 前台代碼(設置一個按鈕)

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>導出excel模板</title>
    <script th:src="@{|/js/jquery-2.1.4.min.js|}"></script>
    <script>
        $(function () {

            $("#exportExcelModel").bind("click",function () {
                window.location.href = "/exportExcelModel";
            })

        })
    </script>
</head>
<body>
    <button id="exportExcelModel">導出excel模板</button>
</body>
</html>

2. 后台代碼

package com.bjpowernode.excel.exportExcelModel.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;

/**
 * ClassName:ExportExcelModelController
 * Package:com.bjpowernode.excel.exportExcelModel.controller
 * Description:
 *
 * @Date:2019/2/23 15:21
 * @Author: 鄭軍
 */
@Controller
public class ExportExcelModelController {

    @RequestMapping("/toExportExcelModel")
    public String toExportExcelModel() {
        return "exportExcelModel";
    }

    @RequestMapping("/exportExcelModel")
    public void exportExcelModel(HttpServletRequest request,
                                 HttpServletResponse response) {
        // 模板名稱
        String fileName = "失信.xlsx";
        String excelName = "失信";

        InputStream inputStream = null;
        OutputStream outputStream = null;

        try {

            /**
             * 設置excel文件導出的時候,瀏覽器響應頭
             */
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Content-disposition", "attachment;fileName=" + new String(excelName.getBytes("utf-8"), "iso-8859-1") + ".xlsx");

            // 讀取服務器中配置好的excel模板
            inputStream = ExportExcelModelController.class.getClassLoader().
                    getResourceAsStream(fileName);

            /**
             * 讀取excel中的數據,然后通過outputStream輸出流輸出
             */
            outputStream = response.getOutputStream();
            byte[] bytes = new byte[1024];
            int length = inputStream.read(bytes);
            while (length > 0) {
                outputStream.write(bytes, 0, length);
                length = inputStream.read(bytes);
            }

        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (inputStream != null) {
                try {
                    inputStream.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

            if (outputStream != null) {
                try {
                    outputStream.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

    }


}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM