EasyExcel通用导入 | 简单封装

        • [0. 前言:](#0. 前言:)
        • [1. 基本思路:](#1. 基本思路:)
        • [2. 调用代码:](#2. 调用代码:)
0. 前言:

之前做了好几个导入,用EasyExcel每次都要定义监听器去处理,就想能不能做个通用的方式,如下

1. 基本思路:

导入无非主要就是参数校验和数据保存

  • 通过hibernate-validator可以做简单的参数校验,通过Consumer函数式接口可以再做校验
  • 数据的保存也是通过Consumer函数式接口由调用端处理,也可以再次做一些批量业务检查、赋值
  • 至于怎么保存,异步异步,由调用端控制,简而言之,只做了简单的封装
2. 调用代码:

组件见项目地址:commons-importing-spring-boot-starter

【主要核心代码】:

【调用代码】:

java 复制代码
   public Response<ImportResultVO> createTaskTest(AdminFollowUpSaveVO saveVO, MultipartFile file) {
        Importer<FollowUpTaskUploadExcelVO> importer = importing.getImporter(FollowUpTaskUploadExcelVO.class);
        try {
            importer.file(file.getInputStream());
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
        importer.dbConsumer(o -> {
            List<FollowUpTaskUploadExcelVO> list = (List<FollowUpTaskUploadExcelVO>) o;
            this.checkData(list);
            this.saveData(list);
        });
        importer.startImport();
        return Response.success(importer.getImportResultVO());
    }
相关推荐
czlczl200209257 分钟前
OAuth 2.0 解析:后端开发者视角的原理与流程讲解
java·spring boot·后端
颜淡慕潇15 分钟前
Spring Boot 3.3.x、3.4.x、3.5.x 深度对比与演进分析
java·后端·架构
g***557517 分钟前
Java高级开发进阶教程之系列
java·开发语言
阿达King哥27 分钟前
在Windows11下编译openjdk 21
java·jvm
shark-chili1 小时前
从操作系统底层浅谈程序栈的高效性
java
不知疲倦的仄仄1 小时前
第二天:深入理解 Selector:单线程高效管理多个 Channel
java·nio
期待のcode1 小时前
Java虚拟机栈
java·开发语言·jvm
珂朵莉MM1 小时前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
芒克芒克1 小时前
本地部署SpringBoot项目
java·spring boot·spring
cute_ming1 小时前
关于基于nodeMap重构DOM的最佳实践
java·javascript·重构