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());
    }
相关推荐
缘空如是1 分钟前
基础工具之jsoup工具
java·jsoup·html解析
毕设源码-郭学长3 分钟前
【开题答辩全过程】以 基于Nodejs的网上书店 为例,包含答辩的问题和答案
java·eclipse
you-_ling11 分钟前
Linux软件编程:Shell命令
java·linux·服务器
数智工坊13 分钟前
【数据结构-栈、队列、数组】3.3栈在括号匹配-表达式求值上
java·开发语言·数据结构
凌康ACG13 分钟前
Warm-Flow国产工作流引擎入门
java·工作流引擎·flowable·warm-flow
知我心·18 分钟前
Java 正则表达式知识点总结
java
indexsunny19 分钟前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices
小疙瘩22 分钟前
去掉 IDEA 中 mybatis配置文件的局部背景颜色(图解)
java·ide·intellij-idea
xqqxqxxq23 分钟前
洛谷算法1-3 暴力枚举(NOIP经典真题解析)java(持续更新)
java·开发语言·算法
逝水如流年轻往返染尘26 分钟前
正则表达式字符串
java·正则表达式