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);
}
相关推荐
西岸行者5 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意5 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
LAM LAB5 天前
【VBA】Excel指定单元格范围内字体设置样式,处理导出课表单元格
excel·vba
别催小唐敲代码5 天前
嵌入式学习路线
学习
毛小茛5 天前
计算机系统概论——校验码
学习
babe小鑫5 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
在这habit之下5 天前
Keepalived学习总结
excel
winfreedoms5 天前
ROS2知识大白话
笔记·学习·ros2
在这habit之下5 天前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs
我想我不够好。5 天前
2026.2.25监控学习
学习