记录后台使用Easy Excel导出Excel为Base64传到前台解析问题

/**
     *
     * @param list 数据
     * @param clazz EasyExcel 表格Modal
     * @return
     */
    public static <T> String exportExcelToBase64(List<T> list, Class<T> clazz) {
        ByteArrayOutputStream out = new ByteArrayOutputStream();
        ExcelWriter excelwriter = EasyExcel.write(out).build();
        WriteSheet sheet = EasyExcel.writerSheet(1, "sheet0").build();
        WriteTable table = new WriteTable();
        table.setClazz(clazz);
        excelwriter.write(list, sheet, table);
        excelwriter.finish();
        InputStream inputStream = new ByteArrayInputStream(out.toByteArray());
        return Base64Util.fileToBase64(inputStream);
    }
/**
     * @return String
     * @description 将文件转base64字符串
     */
    public static String fileToBase64(InputStream inputStream) {
        // 将文件转化为字节数组字符串,并对其进行Base64编码处理
        byte[] data = null;
        // 读取文件字节数组
        try {
            ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
            byte[] buff = new byte[2048];
            int rc = 0;
            while ((rc = inputStream.read(buff, 0, 100)) > 0) {
                swapStream.write(buff, 0, rc);
            }
            data = swapStream.toByteArray();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (inputStream != null) {
                try {
                    inputStream.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

        return Base64.encodeBase64String(data);
    }

前台demo 引用其他博客文章

https://www.jianshu.com/p/d625fd88146d

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>base64ToExcel</title>
    </head>
    <body>
        请输入base64串
        <button onclick="submit()">生成excel</button>
        <br /><br />
        <input id="test" style="width: 800px; height: 30px" />

        <script>
            function submit() {
                let data = document.getElementById("test").value;
                saveData(data, "test.xlsx");
            }

            function saveData(data, filename) {
                let blob = dataURItoBlob(data);
                let objectUrl = URL.createObjectURL(blob);
                //let spl = filename.split(".");
                //window.open(objectUrl,'_blank','alwaysRaised=yes,height=500, width=800, toolbar= no, menubar=no, scrollbars=no, resizable=no, location=yes, status=no,top=100,left=300')
                let aLink = document.createElement("a"); //新添加的  尝试
                let evt = document.createEvent("HTMLEvents");
                evt.initEvent("click", true, true);
                aLink.download = filename; //新添加的  尝试
                aLink.href = objectUrl;
                aLink.click();
                //没有清理的 DOM 元素引用
                //document.body.removeChild(aLink)
            }
            /**
             * base64  to blob二进制
             */
            function dataURItoBlob(dataURI) {
                debugger;
                var byteString = window.atob(dataURI); //base64 解码
                var arrayBuffer = new ArrayBuffer(byteString.length); //创建缓冲数组
                var intArray = new Uint8Array(arrayBuffer); //创建视图
                for (var i = 0; i < byteString.length; i++) {
                    intArray[i] = byteString.charCodeAt(i);
                }

                // return new Blob([intArray],{type: "application/vnd.ms-excel;charset=utf-8;"});//原来封装好的 下载的是excel

                return new Blob([intArray], {
                    type: "application/octet-stream;charset=utf-8;",
                }); //修改-1
            }
        </script>
    </body>
</html>

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用easy excel导出Excel文件可以通过以下步骤完成: 1. 首先,确保已经安装了Java开发环境以及easyexcel的相关依赖包,例如alibaba easyexcel。 2. 导入easyexcel相关的类和包,例如`com.alibaba.excel.EasyExcel`。 3. 创建一个ExcelWriter对象,用于写入Excel文件。可以指定要生成的Excel文件的路径和文件名。 4. 创建一个Sheet对象,并设置sheet的名称。 5. 创建一个List集合,用于存储要导出的数据。 6. 将数据逐一添加到List集合中。 7. 调用ExcelWriter对象的write方法,将数据写入到Sheet中。 8. 最后,调用ExcelWriter对象的finish方法,关闭资源,生成Excel文件。 下面是一个示例代码: ```java import com.alibaba.excel.EasyExcel; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.Sheet; import com.alibaba.excel.metadata.Table; import java.util.ArrayList; import java.util.List; public class ExportExcel { public static void main(String[] args) { // 创建ExcelWriter对象,并指定要生成的Excel文件的路径及名称 ExcelWriter excelWriter = EasyExcel.write("D:\\test.xlsx").build(); // 创建Sheet对象,并设置sheet的名称 Sheet sheet = new Sheet(1, 0); sheet.setSheetName("Sheet1"); // 创建一个 List 集合,用于存储要导出的数据 List<List<String>> data = new ArrayList<>(); // 向 List 中逐一添加数据 List<String> item = new ArrayList<>(); item.add("姓名"); item.add("年龄"); data.add(item); item = new ArrayList<>(); item.add("张三"); item.add("25"); data.add(item); // 将数据写入到 Sheet 中 excelWriter.write(data, sheet); // 关闭资源,生成Excel文件 excelWriter.finish(); } } ``` 以上代码会生成一个名为test.xlsx的Excel文件,其中包含一个名为Sheet1的工作表,表格中有两列数据:姓名和年龄,其中姓名为张三,年龄为25。 这样就可以使用easyexcel导出Excel文件了。注意,使用easyexcel还可以导出更复杂的Excel文件,例如多个工作表、自定义样式等。详细的用法可以参考easyexcel的官方文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值