管道基础大数据平台系统开发-【后端】-Server
13693261870
2024-02-27 d5c36090a84b75395fc3f33661c5d7007a6907c5
集中设置目录编码
已修改2个文件
82 ■■■■ 文件已修改
src/main/java/com/lf/server/service/all/BaseUploadService.java 74 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/resources/application.yml 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/service/all/BaseUploadService.java
@@ -196,26 +196,24 @@
        }
        List<MetaFileEntity> list = new ArrayList<>();
        List<DirEntity> dirs = dirService.selectRecursiveById(dir.getId());
        for (MetaFileEntity meta : metas) {
            meta.setEventid(StringHelper.getGuid());
            meta.setDircode(dir.getCode());
            meta.setDepcode(ue.getDepcode());
            meta.setVerid(ver.getId());
            meta.setCreateUser(ue.getId());
            meta.setEpsgCode(epsgCode);
            if (StaticData.ZIP.equals(meta.getExtName())) {
                List<MetaFileEntity> subs = getMapperFiles(path, dir, dirs, meta);
                List<MetaFileEntity> subs = getMapperFiles(path, meta);
                if (null != subs && subs.size() > 0) {
                    list.addAll(subs);
                    continue;
                }
            }
            list.add(meta);
        }
        setMetaType(list);
        setDircode(list, dir);
        return list;
    }
@@ -223,7 +221,7 @@
    /**
     * 获取映射文件
     */
    private List<MetaFileEntity> getMapperFiles(String path, DirEntity dir, List<DirEntity> dirs, MetaFileEntity meta) {
    private List<MetaFileEntity> getMapperFiles(String path, MetaFileEntity meta) {
        String tempPath = pathHelper.getConfig().getTempPath();
        String zipFile = tempPath + File.separator + meta.getPath();
        File file = new File(zipFile);
@@ -243,7 +241,7 @@
        List<File> files = new ArrayList<>();
        getFilesByPath(files, subPath);
        return getMapperFiles(files, dir, dirs, meta, tempPath.length() + 1);
        return getMapperFiles(files, meta, tempPath.length() + 1);
    }
    /**
@@ -300,7 +298,7 @@
    /**
     * 获取映射文件
     */
    private List<MetaFileEntity> getMapperFiles(List<File> files, DirEntity dir, List<DirEntity> dirs, MetaFileEntity meta, int start) {
    private List<MetaFileEntity> getMapperFiles(List<File> files, MetaFileEntity meta, int start) {
        List<MetaFileEntity> list = new ArrayList<>();
        for (File f : files) {
            boolean isGdb = isGdbFile(f);
@@ -316,22 +314,20 @@
                continue;
            }
            String dircode = getDirByPath(f.getPath(), fileName, dir, dirs);
            if (isGdb) {
                List<MetaFileEntity> rs = getGdbMappers(f, meta, dircode, start);
                List<MetaFileEntity> rs = getGdbMappers(f, meta, start);
                if (null != rs && rs.size() > 0) {
                    list.addAll(rs);
                }
                continue;
            }
            if (isOsgb) {
                list.add(getOsgbMapper(f, meta, dircode, start));
                list.add(getOsgbMapper(f, meta, start));
                continue;
            }
            MetaFileEntity mf = createMetaFileEntity(f, meta, fileName, extName);
            mf.setPath(f.getPath().substring(start));
            mf.setDircode(dircode);
            list.add(mf);
        }
@@ -367,35 +363,12 @@
     */
    private MetaFileEntity createMetaFileEntity(MetaFileEntity meta) {
        MetaFileEntity mf = new MetaFileEntity();
        mf.setDircode(meta.getDircode());
        mf.setDepcode(meta.getDepcode());
        mf.setVerid(meta.getVerid());
        mf.setCreateUser(meta.getCreateUser());
        mf.setEpsgCode(meta.getEpsgCode());
        return mf;
    }
    /**
     * 根据文件路径获取目录ID
     */
    private String getDirByPath(String filePath,String fileName, DirEntity dir, List<DirEntity> dirs) {
        if (0 != dir.getPid() || null == dirs || dirs.isEmpty()) {
            return dir.getCode();
        }
        if (StaticData.SLASH.equals(File.separator)) {
            filePath = filePath.replace("/", "\\");
        }
        fileName = fileName.toLowerCase();
        filePath = filePath.toLowerCase();
        for (DirEntity entity : dirs) {
            if (filePath.contains(entity.getFullName().toLowerCase() + "\\" + fileName)) {
                return entity.getCode();
            }
        }
        return dir.getCode();
    }
    /**
@@ -472,7 +445,7 @@
    /**
     * 获取GDB文件映射
     */
    private List<MetaFileEntity> getGdbMappers(File f, MetaFileEntity meta, String dircode, int start) {
    private List<MetaFileEntity> getGdbMappers(File f, MetaFileEntity meta, int start) {
        List<String> tabs = GdbHelper.getTabNames(f.getPath());
        if (null == tabs || tabs.size() == 0) {
            return null;
@@ -488,7 +461,6 @@
        List<MetaFileEntity> list = new ArrayList<>();
        for (String tab : tabs) {
            MetaFileEntity mf = createMetaFileEntity(meta);
            mf.setDircode(dircode);
            mf.setEventid(StringHelper.getGuid());
            mf.setName(fileName + "\\" + tab);
            mf.setExtName(extName);
@@ -551,11 +523,10 @@
        return false;
    }
    /**
     * 获取OSGB文件映射
     */
    private MetaFileEntity getOsgbMapper(File f,  MetaFileEntity meta, String dircode, int start) {
    private MetaFileEntity getOsgbMapper(File f,  MetaFileEntity meta, int start) {
        String fileName = FileHelper.getFileName(f.getPath());
        List<String> files = new ArrayList<>();
@@ -565,7 +536,6 @@
        double sizes = getFilesSize(files);
        MetaFileEntity mf = createMetaFileEntity(meta);
        mf.setDircode(dircode);
        mf.setEventid(StringHelper.getGuid());
        mf.setName(fileName);
        mf.setExtName(StaticData.OSGB);
@@ -578,6 +548,32 @@
    }
    /**
     * 设置目录编码
     */
    private void setDircode(List<MetaFileEntity> list, DirEntity dir) {
        List<DirEntity> dirs = dirService.selectRecursiveById(dir.getId());
        if (null == dirs || dirs.isEmpty()) {
            for (MetaFileEntity mfe : list) {
                mfe.setDircode(dir.getCode());
            }
            return;
        }
        for (MetaFileEntity mfe : list) {
            String code= dir.getCode();
            String fileName = mfe.getName().toLowerCase();
            String filePath = mfe.getPath().replace("/", "\\").toLowerCase();
            for(DirEntity de : dirs){
                if (filePath.contains(de.getFullName().toLowerCase() + "\\" + fileName)) {
                    code=de.getCode();
                    break;
                }
            }
            mfe.setDircode(code);
        }
    }
    /**
     * 获取参数 *
     * Enumeration<String> headers = req.getHeaderNames();
     * Enumeration<String> attributes = req.getAttributeNames();
src/main/resources/application.yml
@@ -46,11 +46,11 @@
    name: prod
    # JDBC 基本配置 &currentSchema=public
    #url: jdbc:postgresql://103.135.160.14:5433/langfang?useAffectedRows=true
    url: jdbc:postgresql://192.168.11.205:5433/langfang?useAffectedRows=true
    #url: jdbc:postgresql://127.0.0.1:5433/langfang?useAffectedRows=true
    #url: jdbc:postgresql://192.168.11.205:5433/langfang?useAffectedRows=true
    url: jdbc:postgresql://127.0.0.1:5433/langfang?useAffectedRows=true
    username: postgres
    password: Postgres!_14_Lf
    #password: postgres
    #password: Postgres!_14_Lf
    password: postgres
    driver-class-name: org.postgresql.Driver
    platform: POSTGRESQL
    type: com.alibaba.druid.pool.DruidDataSource