EasyExcel 学习之 导出 “提示问题”

EasyExcel 学习之 导出 "提示问题"

现象

EasyExcel 支持导出 xlsxxlscsv 三种文件格式。在导出过程中可能发生各种异常,当发生异常时应该提示错误信息而非导出一个错误的文件。

分析

  • 首先,后端应该支持两种不同格式(content-type)内容的返回
  • 其次,前端应该支持两种不同格式(content-type)内容的解析处理

解决(伪代码)

前端 POST 实现

javascript 复制代码
const axios = require('axios');

axios({
	url: 'https://api.example.com/export',
	method: 'post',
	data: {
		param1: 'value1',
		param2: 'value2'
	},
	responseType: 'blob',
	headers: {
		'Authorization': 'Bearer YOUR_TOKEN'
	}
})
.then(response => {
	if (response.data && response.data.type == 'application/json') {
		const render = new FileReader();
		reader.onload = (e) => {
			let content = e.target.result;
			content = JSON.parse(content);
			this.$antMessage.info(content.msg);
		}
	} else {
		var blob = new Blob([response.data]);
		const url = window.URL.createObjectURL(blob);
		const link = document.createElement('a');
		link.style.display = 'none';
		link.href = url;
		link.setAttribute('download', name);
		document.body.appendChild(link);
		link.click();
		document.body.removeChild(link);
	}
})
.catch(error => {
  	console.error('Error:', error);
});

后端实现

java 复制代码
if (errorCondition) {
	throw new BusinessException('errorCode', 'errorMsg');
}

response.setContentType(ExcelConst.MEDIA_TYPE_EXCEL);
response.setHeader(ExcelConst.CONTENT_DISPOSITION, String.format("%s:%s=%s.%s", ExcelConst.ATTACHMENT, ExcelConst.FILENAME, System.currentTimeMillis(), ExcelTypeEnum.XLSX.getValue()));

try (OutputStream os = response.getOutputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream()) {
    ExcelWriter excelWriter = EasyExcel.write(baos)
            .charset(Charset.forName("GBK")) // 或者 UTF-8
            .autoCloseStream(true)
            .excludeColumnFieldNames(Lists.newArrayList())
            .excelType(ExcelTypeEnum.XLSX).build();

	WriteSheet writeSheet = EasyExcel.writerSheet(sheetNo, sheetName).head(clazz).build();
	excelWriter.write(sheetData, writeSheet);

    excelWriter.finish();

    os.write(baos.toByteArray());
} catch (Exception e) {
    log.error(String.format("Excel 导出失败!%s", ""), e);
}
相关推荐
secondyoung10 小时前
Cortex-R52学习:MPU内存保护机制
arm开发·单片机·学习·arm·mpu
red_redemption10 小时前
自由学习记录(198)
学习
花岛溯10 小时前
Cursor 学习 DAY2·切换AI模型
学习
星夜夏空9910 小时前
FreeRTOS学习(9)——临界区
学习
小智老师PMP12 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程
XGeFei13 小时前
【Fastapi学习笔记(4)】—— JsonScheme与数据验证、错误响应格式、正则表达式
学习·fastapi
爱喝水的鱼丶14 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
東雪木14 小时前
泛型、反射、注解(Spring 框架核心底层)专属复习笔记
java·windows·笔记·学习·spring
小陈phd15 小时前
多模态大模型学习笔记(四十七)——跨模态融合策略:早融合、中融合与晚融合核心解析
笔记·学习
进击的小头15 小时前
第7篇:MOS 管最全入门:原理、关键参数、选型、驱动与典型应用
经验分享·科技·嵌入式硬件·学习