【贫民版】Springboot导入返回错误Excel表格 ---- 通过session存储字节数据,再获取写到响应体中。

本文主要是介绍【贫民版】Springboot导入返回错误Excel表格 ---- 通过session存储字节数据,再获取写到响应体中。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 前言
  • 一、需求
  • 二、需求分析
  • 三、代码


前言

在开发中会遇到导入文件后,失败的数据需要整理在加上导入失败原因。

按照目前主流的方法,要么通过流输出到response响应体中,或者把失败的excel上传到服务器中,返回url让前端下载。


一、需求

导入文件后,把未满足条件的记录和未满足的原因导出,让业务人员修改后二次导入。

二、需求分析

1、当前端请求到后端时,可以直接通过response直接导出文件,但是会有其他情况,前端需要返回码去判断展示不同的页面。

2、故放弃第1种方法,需要让 excel 暂存在一个地方 , 通过返回的数据, 由前端判断去获取excel。

3、有多种实现方法。 本文主要介绍的是在 session中存储。

三、代码

相关依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.3.2</version>
</dependency>

controller

package com.example.springboot_demo.testImpl;import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.write.builder.ExcelWriterBuilder;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream;
import java.util.ArrayList;
import java.util.List;@RestController
@Slf4j
public class TestController {@GetMapping("/import")public String test2(@RequestParam(value = "file", required = false) MultipartFile file, HttpServletRequest request){// TODO 处理file// 构造错误数据List<TempFileUtil.ErrorExportVO> errorExportVOList = new ArrayList<>();TempFileUtil.ErrorExportVO exportVO1 = new TempFileUtil.ErrorExportVO();exportVO1.setFileName("我是错误的文件名!");exportVO1.setErrorMsg("文件名错误!");TempFileUtil.ErrorExportVO exportVO2 = new TempFileUtil.ErrorExportVO();exportVO2.setFileName("我是错误的文件名2!");exportVO2.setErrorMsg("文件名错误2!");errorExportVOList.add(exportVO1);errorExportVOList.add(exportVO2);String uuid;try{ByteArrayOutputStream outputStream = new ByteArrayOutputStream();ExcelWriterBuilder write = EasyExcel.write(outputStream, TempFileUtil.ErrorExportVO.class);write.sheet("sheet1").doWrite(errorExportVOList);uuid = TempFileUtil.addExcel(request, outputStream, "错误信息");outputStream.close();}catch (Exception e) {throw new RuntimeException(e);}return uuid;}//下载临时文件@GetMapping("/downloadTempFile")public void downloadTempFile(@RequestParam("tempFileId") String tempFileId,HttpServletRequest request, HttpServletResponse response) {final TempFileUtil.TempFileBean fileBean = TempFileUtil.get(request, tempFileId);if (fileBean == null) {throw new RuntimeException("对象不存在!");}TempFileUtil.exportBinary(fileBean, response);TempFileUtil.remove(request, tempFileId);}
}

工具类。 为了方便阅读,把实体类放到里面了。

package com.example.springboot_demo.testImpl;import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.support.ExcelTypeEnum;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.ByteArrayOutputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;@Slf4j
public class TempFileUtil {@SuppressWarnings("unchecked")private static Map<String, TempFileBean> getFileMap(HttpServletRequest request) {if (request == null) {return new HashMap<>();}final HttpSession session = request.getSession();if (session.getAttribute("fileMap") == null) {session.setAttribute("fileMap", new HashMap<String, TempFileBean>());}return (Map<String, TempFileBean>) session.getAttribute("fileMap");}public static void put(HttpServletRequest request, final TempFileBean fileBean) {getFileMap(request).put(fileBean.getFileId(), fileBean);}public static TempFileBean get(HttpServletRequest request, final String fileId) {return getFileMap(request).get(fileId);}public static void remove(HttpServletRequest request, final String fileId) {getFileMap(request).remove(fileId);}public static String addExcel(HttpServletRequest request, ByteArrayOutputStream outputStream, String fileName) {byte[] excelData = outputStream.toByteArray();TempFileBean fileBean = new TempFileBean();String fileId = UUID.randomUUID().toString();fileBean.setFileId(fileId);fileBean.setFileName(fileName);fileBean.setFileContent(excelData);TempFileUtil.put(request, fileBean);return fileId;}public static void exportBinary(TempFileBean fileBean, HttpServletResponse response) {try {// 对中文文件名进行 URL 编码String encodedFileName = URLEncoder.encode(fileBean.getFileName(), "utf-8") + ExcelTypeEnum.XLSX.getValue();response.setContentType("multipart/form-data");response.setCharacterEncoding("utf-8");response.setContentType("application/vnd.ms-excel;charset=utf-8");response.setHeader("Content-Disposition", "attachment; filename=" + encodedFileName);try (OutputStream os = response.getOutputStream()) {os.write(fileBean.getFileContent());os.flush();} catch (Exception e) {log.info("系统异常");}} catch (Exception e) {log.info("系统异常");}}@Datapublic static class TempFileBean {private String fileId;private String fileName;private byte[] fileContent;}@Datapublic static class ErrorExportVO {@ExcelProperty(value = "文件名")@ColumnWidth(30)private String fileName;@ExcelProperty(value = "错误原因")@ColumnWidth(30)private String errorMsg;}
}

在这里插入图片描述

这篇关于【贫民版】Springboot导入返回错误Excel表格 ---- 通过session存储字节数据,再获取写到响应体中。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/856186

相关文章

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Springboot的自动配置是什么及注意事项

《Springboot的自动配置是什么及注意事项》SpringBoot的自动配置(Auto-configuration)是指框架根据项目的依赖和应用程序的环境自动配置Spring应用上下文中的Bean... 目录核心概念:自动配置的关键特点:自动配置工作原理:示例:需要注意的点1.默认配置可能不适合所有场景

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链