shikeyin
2024-01-11 65da8373531677b1c37a98f53eaa30c892f35e5a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package com.iplatform.base.config;
 
import com.iplatform.base.LocalDatabaseMetaEngine;
import com.iplatform.base.di.PlatformDataImportEngine;
import com.iplatform.base.di.PlatformExcelTemplateGenerator;
import com.walker.di.excel.ExcelTemplateGenerator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
/**
 * 数据导入、导出配置。
 * @author 时克英
 * @date 2023-02-07
 */
@Configuration
public class DataImportConfig {
 
    /**
     * 配置导入数据引擎对象,负责整个Excel导入功能。
     * @param excelTemplateGenerator
//     * @param fileOperateSpi 文件操作服务提供者接口
     * @param fileProperties 文件管理配置属性
     * @return
     * @date 2023-02-07
     * @date 2023-02-15
     */
    @Bean
    public PlatformDataImportEngine dataImportEngine(ExcelTemplateGenerator excelTemplateGenerator
//            , FileOperateSpi fileOperateSpi
            , FileProperties fileProperties){
        PlatformDataImportEngine dataImportEngine = new PlatformDataImportEngine();
//        dataImportEngine.setSaveFileRoot("d:/tmp/");
        /** 这里只能设置本机磁盘路径,因为导入文件都是本机操作(到数据库)的,不会涉及服务集群。2023-02-15 */
        dataImportEngine.setSaveFileRoot(fileProperties.getFileRoot());
        dataImportEngine.setTemplateGenerator(excelTemplateGenerator);
        return dataImportEngine;
    }
 
    /**
     * Excel导入系统根据表名自动生成导入模板。
     * @param localDatabaseMetaEngine
     * @return
     * @date 2023-02-07
     */
    @Bean
    public ExcelTemplateGenerator excelTemplateGenerator(LocalDatabaseMetaEngine localDatabaseMetaEngine){
        PlatformExcelTemplateGenerator excelTemplateGenerator = new PlatformExcelTemplateGenerator();
        excelTemplateGenerator.setLocalDatabaseMetaEngine(localDatabaseMetaEngine);
        return excelTemplateGenerator;
    }
}