管道基础大数据平台系统开发-【后端】-Server
12
13693261870
2022-11-21 07a68b8d93aa059968a9709f2c81e6625338032c
12
已修改5个文件
68 ■■■■■ 文件已修改
src/main/java/com/lf/server/entity/ctrl/TabMapperEntity.java 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/helper/GdbHelper.java 34 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/helper/MdbHelper.java 19 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/helper/ShpHelper.java 10 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/service/data/DataLoaderService.java 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/lf/server/entity/ctrl/TabMapperEntity.java
@@ -12,7 +12,6 @@
        this.fileName = fileName;
        this.type = type;
        this.tab = tab;
    }
    public TabMapperEntity(String fileName, String type, String tab, String subPath) {
src/main/java/com/lf/server/helper/GdbHelper.java
@@ -43,14 +43,46 @@
    /**
     * 读取数据
     */
    public static <T> List<T> readData(Class clazz, String filePath) {
    public static <T> List<T> readData(Class clazz, String filePath, String layerName) {
        List<T> list = new ArrayList<>();
        try {
            org.gdal.ogr.Driver driver = ogr.GetDriverByName("OpenFileGDB");
            if (driver == null) {
                return list;
            }
            DataSource dataSource = driver.Open(filePath, 0);
            for (int i = 0, count = dataSource.GetLayerCount(); i < count; i++) {
                Layer layer = dataSource.GetLayer(i);
                if (layer.GetName().equals(layerName)) {
                    GdbHelper.readLayer(clazz, layer, list);
                    break;
                }
                layer.delete();
            }
            driver.delete();
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
        return list;
    }
    /**
     * 读取图层
     */
    public static <T> void readLayer(Class clazz, Layer layer, List<T> list) {
        try {
            //
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        } finally {
            if (null != layer) {
                layer.delete();
            }
        }
    }
}
src/main/java/com/lf/server/helper/MdbHelper.java
@@ -43,10 +43,27 @@
    /**
     * 读取数据
     */
    public static <T> List<T> readData(Class clazz, String filePath) {
    public static <T> List<T> readData(Class clazz, String filePath, String layerName) {
        List<T> list = new ArrayList<>();
        try {
            org.gdal.ogr.Driver driver = ogr.GetDriverByName("PGeo");
            if (driver == null) {
                return list;
            }
            DataSource dataSource = driver.Open(filePath, 0);
            for (int i = 0, count = dataSource.GetLayerCount(); i < count; i++) {
                Layer layer = dataSource.GetLayer(i);
                if (layer.GetName().equals(layerName)){
                    GdbHelper.readLayer(clazz, layer, list);
                    break;
                }
                layer.delete();
            }
            driver.delete();
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
src/main/java/com/lf/server/helper/ShpHelper.java
@@ -200,7 +200,17 @@
    public static <T> List<T> readData(Class clazz, String filePath) {
        List<T> list = new ArrayList<>();
        try {
            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
            if (driver == null) {
                return list;
            }
            DataSource dataSource = driver.Open(filePath);
            Layer layer = dataSource.GetLayer(0);
            GdbHelper.readLayer(clazz, layer, list);
            driver.delete();
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
src/main/java/com/lf/server/service/data/DataLoaderService.java
@@ -452,10 +452,10 @@
                    list = ShpHelper.readData(clazz, root + File.separator + tab.getSubPath());
                    break;
                case "gdb":
                    list = GdbHelper.readData(clazz, root + File.separator + tab.getSubPath());
                    list = GdbHelper.readData(clazz, root + File.separator + tab.getSubPath(), tab.getTab());
                    break;
                case "mdb":
                    list = MdbHelper.readData(clazz, root + File.separator + tab.getSubPath());
                    list = MdbHelper.readData(clazz, root + File.separator + tab.getSubPath(), tab.getTab());
                    break;
                default:
                    break;