Spring WebFlux + React搭建后台管理系统(7): 实现excel文件上传下载

本文主要是介绍Spring WebFlux + React搭建后台管理系统(7): 实现excel文件上传下载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

后台管理系统的excel导出功能,以及使用excel进行批量导入都是必不可少的功能,本篇主要介绍内容如下:

  • java后端 excel的读写
  • excel类型判断以及通过反射适配class
  • 后端接收upload服务逻辑实现
  • 后端download服务逻辑
  • 前端upload组建使用
  • 前端download配置

先上效果图:

在这里插入图片描述

1. 读取Excel文件

1.1 添加依赖

通过使用poi进行excel文件的解析:

implementation 'org.apache.poi:poi:4.0.1'
implementation 'org.apache.poi:poi-ooxml:4.0.1'

版本不要太高容易报错,spring使用的基础包版本可能不支持

1.2 生成workbook

  • workbook是excel的基本类,输入一个inputStream,作为数据源
  • 用过workbook生成一个sheet
  • 通过sheet生成row,用过row生成cell
  • 读取就是获取cell中的数据,写入就是将数据写入cell,设置cell的Style等
  • 由于xls和xlsx版本不同,xls只是xml写的文件,而xlsx是一个压缩包,解析模板不同,需要通过不同的解析系统生成workbook
    private static final String XLS = "xls";private static final String XLSX = "xlsx";public static Workbook getWorkbook(InputStream inputStream, String fileType) throws IOException {Workbook workbook = null;if (fileType.equalsIgnoreCase(XLS)) {workbook = new HSSFWorkbook(inputStream);} else if (fileType.equalsIgnoreCase(XLSX)) {workbook = new XSSFWorkbook(inputStream);}return workbook;}
  • 生成sheet
Sheet sheet = workbook.getSheetAt(sheetId);

1.3 获取类数据

  • 为了方便使用反射,这里默认表格第一行为属性名
  • 根据表格中顺序获取属性名
Row header = sheet.getRow(0);
if (header == null) {log.warn("解析失败表头没有数据");return null;
}
int columnNum = header.getPhysicalNumberOfCells();
String[] properties = new String[columnNum];
for (int i = 0; i < properties.length; i++) {properties[i] = header.getCell(i).toString();
}
  • 因为要转化为对象,这里获取类的所有set方法
  • 获取所有属性对应的类型
Map<String, Method> methods = Stream.of(clazz.getMethods()).filter(method -> method.getName().startsWith("set")).collect(Collectors.toMap(Method::getName, it->it));Map<String, Type> fieldMap = Stream.of(clazz.getDeclaredFields()).collect(Collectors.toMap(Field::getName, Field::getType));

1.4 获取数据

  • 通过循环行获取row
  • row循环列获取cell
  • 通过cell获取数据
  • 通过反射将以及对应set方法,将数据写入对象
var objs = new ArrayList<>();
for (int i = startRowNum; i <= endRowNum; ++i) {Row row = sheet.getRow(i);if (row == null) continue;Object obj = clazz.getDeclaredConstructor().newInstance();try {for (int j = 0; j < columnNum; j++) {var methodName = "set" + properties[j].substring(0, 1).toUpperCase() + properties[j].substring(1);if (methods.containsKey(methodName)){Method method = methods.get(methodName);Cell cell = row.getCell(j);Type type = fieldMap.get(properties[j]);method.invoke(obj,cell2Obj(cell, type));}}} catch</

这篇关于Spring WebFlux + React搭建后台管理系统(7): 实现excel文件上传下载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

javacv依赖太大导致jar包也大的解决办法

《javacv依赖太大导致jar包也大的解决办法》随着项目的复杂度和依赖关系的增加,打包后的JAR包可能会变得很大,:本文主要介绍javacv依赖太大导致jar包也大的解决办法,文中通过代码介绍的... 目录前言1.检查依赖2.更改依赖3.检查副依赖总结 前言最近在写项目时,用到了Javacv里的获取视频

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu