月球大数据地理空间分析展示平台-【后端】-月球后台服务
13693261870
2023-09-02 2fcbeffa30bc674cffdd0147da271754468073a3
修改发布服务控制器-1
已修改4个文件
240 ■■■■ 文件已修改
src/main/java/com/moon/server/controller/data/PublishController.java 125 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/moon/server/service/data/PublishService.java 55 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/moon/server/service/data/ShuJianService.java 51 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/resources/application.yml 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/moon/server/controller/data/PublishController.java
@@ -61,7 +61,7 @@
                return fail("数据类别为空", null);
            }
            String types = getType(dircode, type);
            String types = getType(type);
            int count = publishService.selectMetasByCount(depcode, dircode, verid, types, name);
            if (count == 0) {
                return success(0, null);
@@ -78,55 +78,19 @@
    /**
     * 获取类型
     */
    private String getType(String dircode, String type) throws Exception {
    private String getType(String type) throws Exception {
        switch (type) {
            case "DOM":
                return "type in ('tif', 'tiff', 'img')" + getFilter(dircode, type);
                return "type in ('tif', 'tiff', 'img', 'jp2', 'jpg') and mata_type in (1, 3, 4, 5)";
            case "DEM":
                return "type in ('tif', 'tiff')" + getFilter(dircode, type);
            case "MPT":
                return "type = 'mpt'";
            case "3DML":
                return "type = '3dml'";
            case "CPT":
                return "type = 'cpt'";
            case "BIM":
                return "type in ('ifc', 'fbx', 'rvt')";
            case "LAS":
                return "type in ('las', 'laz')";
            case "OSGB":
                return "type = 'osgb'";
                return "type in ('tif', 'tiff', 'dem') and mata_type = 2";
            case "Vector":
                return "type in ('shp', 'gdb') and mata_type = 6";
            case "Model":
                return "type in ('ifc', 'gdb') and mata_type = 7";
            default:
                throw new Exception("数据类型不匹配");
        }
    }
    /**
     * 获取过滤条件
     */
    private String getFilter(String dircode, String type) {
        dircode = StringHelper.isEmpty(dircode) ? "" : StringHelper.getRightLike(dircode);
        List<String> list = null;
        switch (type) {
            case "DOM":
                list = publishService.selectCodesForDir(dircode, 0);
                break;
            case "DEM":
                list = publishService.selectCodesForDir(dircode, 1);
                break;
            default:
                break;
        }
        if (null == list || list.isEmpty()) {
            return "";
        }
        for (int i = 0, c = list.size(); i < c; i++) {
            list.set(i, "'" + list.get(i) + "'");
        }
        return " and dircode not in (" + StringHelper.join(list, ",") + ")";
    }
    @SysLog()
@@ -162,7 +126,7 @@
    /**
     * 获取发布类型
     */
    private String getPubType(String type) {
    private String getPubType(String type) throws Exception {
        if (StringHelper.isEmpty(type)) {
            return null;
        }
@@ -172,20 +136,12 @@
                return "type = 'DOM'";
            case "DEM":
                return "type = 'DEM'";
            case "MPT":
                return "type = 'mpt'";
            case "3DML":
                return "type = '3dml'";
            case "CPT":
                return "type = 'cpt'";
            case "BIM":
                return "type in ('ifc', 'fbx', 'rvt')";
            case "LAS":
                return "type in ('las', 'laz')";
            case "OSGB":
                return "type = 'osgb'";
            case "Vector":
                return "type = 'Vector'";
            case "Model":
                return "type = 'Model'";
            default:
                return null;
                throw new Exception("数据类型不匹配");
        }
    }
@@ -200,31 +156,6 @@
            PublishEntity entity = publishService.selectById(id);
            return success(entity);
        } catch (Exception ex) {
            return fail(ex.getMessage(), null);
        }
    }
    @SysLog()
    @ApiOperation(value = "查询Las文件坐标系ID")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "ids", value = "元数据ID集合", dataType = "Integer[]", paramType = "query", example = "10483,10481,10456,10285")
    })
    @GetMapping(value = "/selectLasCs")
    public ResponseMsg<Object> selectLasCs(Integer[] ids, HttpServletRequest req) {
        try {
            if (null == ids || ids.length == 0) {
                return fail("元数据ID集合不能为空");
            }
            PubEntity entity = new PubEntity();
            entity.setIds(Arrays.asList(ids));
            entity.setDircode("00");
            entity.setToken(WebHelper.getToken(req));
            List<Integer> list = publishService.selectLasCs(entity, "/Convert/ReadLasCs", req);
            return success(list);
        } catch (Exception ex) {
            return fail(ex.getMessage(), null);
        }
@@ -252,36 +183,12 @@
            }
            permsService.clearPermsCache();
            String method = getConvertMethod(entity.getType());
            long count = publishService.postForPub(entity, method, req);
            // String method = getConvertMethod(entity.getType())
            long count = publishService.postForPub(entity, "", req);
            return success(count);
        } catch (Exception ex) {
            return fail(ex.getMessage(), -1);
        }
    }
    /**
     * 获取转换方法
     */
    private String getConvertMethod(String type) throws Exception {
        switch (type) {
            case "DOM":
                return "/Convert/ToTiles";
            case "DEM":
                return "/Convert/ToTerra";
            case "MPT":
            case "3DML":
            case "CPT":
                return "/Convert/ToSG";
            case "BIM":
                return "/Convert/ToTileset";
            case "LAS":
                return "/Convert/ToLasByPy";
            case "OSGB":
                return "/Convert/ToOsgb";
            default:
                throw new Exception("数据类型不匹配");
        }
    }
src/main/java/com/moon/server/service/data/PublishService.java
@@ -9,9 +9,7 @@
import com.moon.server.helper.PathHelper;
import com.moon.server.helper.RestHelper;
import com.moon.server.helper.StringHelper;
import com.moon.server.helper.WebHelper;
import com.moon.server.mapper.data.PublishMapper;
import com.moon.server.service.sys.TokenService;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Value;
@@ -19,7 +17,6 @@
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.List;
@@ -34,14 +31,11 @@
    @Value("${sys.exportServer}")
    private String exportServer;
    @Value("${sys.iisHost}")
    private String iisHost;
    @Resource
    PublishMapper publishMapper;
    @Resource
    PathHelper pathHelper;
    ShuJianService shuJianService;
    private final static Log log = LogFactory.getLog(PublishService.class);
@@ -134,27 +128,6 @@
        return publishMapper.selectMetasByPage(depcode, dircode, verid, types, name, limit, offset);
    }
    public List<Integer> selectLasCs(PubEntity entity, String method, HttpServletRequest req) {
        Map<String, Object> map = getMapData(entity);
        String str = RestHelper.postForRest(exportServer + method, map);
        if (StringHelper.isEmpty(str)) {
            return null;
        }
        ResponseMsg<String> msg = JSON.parseObject(str, ResponseMsg.class);
        if (msg == null || msg.getCode() != StaticData.TWO_HUNDRED) {
            return null;
        }
        String rs = msg.getResult();
        if (StringHelper.isEmpty(rs)) {
            return null;
        }
        return StringHelper.strToIntegers(rs);
    }
    /**
     * 发送发布请求
     */
@@ -225,28 +198,12 @@
    public Integer deletes(List<Integer> idList, HttpServletRequest req) {
        String ids = StringHelper.join(idList, ",");
        return deletes(ids);
    }
    /**
     * 删除发布文件
     */
    public void deleteFiles(List<PublishEntity> list) {
        String lfData = pathHelper.getConfig().getLfData();
        for (PublishEntity pub : list) {
            if (null != pub.getUrl() && pub.getUrl().contains("/SG/")) {
                continue;
            }
            String path = lfData + pub.getPath().replace("\\tileset.json", "");
            File file = new File(path);
            if (!file.exists() || !file.isDirectory()) {
                continue;
            }
            String cmd = String.format("cmd /c rd \"%s\" /s /q", path);
            WebHelper.exec(cmd);
        List<PublishEntity> list = selectByIds(ids);
        for (PublishEntity entity : list) {
            shuJianService.deleteServe(entity);
        }
        return deletes(ids);
    }
    /**
src/main/java/com/moon/server/service/data/ShuJianService.java
@@ -1,9 +1,13 @@
package com.moon.server.service.data;
import com.moon.server.entity.all.StaticData;
import com.moon.server.entity.data.PublishEntity;
import com.moon.server.entity.shujian.CreateLayerEntity;
import com.moon.server.entity.shujian.CreateServiceEntity;
import com.moon.server.entity.shujian.DeleteEntity;
import com.moon.server.helper.StringHelper;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.stereotype.Service;
import java.util.List;
@@ -14,6 +18,8 @@
 */
@Service
public class ShuJianService {
    private final static Log log = LogFactory.getLog(ShuJianService.class);
    /**
     * 创建数简图层
     */
@@ -42,13 +48,6 @@
    }
    /**
     * 删除数简图层
     */
    public void deleteShuJianLayer() {
        //
    }
    /**
     * 创建数简服务
     */
    public void createShuJianService() {
@@ -70,9 +69,43 @@
    }
    /**
     * 删除数简服务
     */
    public void deleteServe(PublishEntity entity) {
        if (null != entity.getLayerid()) {
            deleteLayer(entity.getLayerid());
        }
        if (null != entity.getServiceid()) {
            deleteService(entity.getServiceid());
        }
    }
    /**
     * 删除数简图层
     */
    public void deleteShuJianService() {
        //
    public void deleteLayer(Integer id) {
        try {
            DeleteEntity entity = new DeleteEntity();
            entity.getId_list().add(id);
            //
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
    }
    /**
     * 删除数简图层
     */
    public void deleteService(Integer id) {
        try {
            DeleteEntity entity = new DeleteEntity();
            entity.getId_list().add(id);
            //
        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        }
    }
}
src/main/resources/application.yml
@@ -15,7 +15,8 @@
  # redis
  redis:
    database: 0
    host: 192.168.20.83
    #host: 192.168.20.83
    host: 127.0.0.1
    port: 6369
    password: rediS_5L#F4_Server
    timeout: 10000  # 连接超时时长(毫秒)
@@ -45,8 +46,8 @@
  datasource:
    name: prod
    # JDBC 基本配置 &currentSchema=public
    url: jdbc:postgresql://192.168.20.83:5433/moon?useAffectedRows=true
    #url: jdbc:postgresql://127.0.0.1:5433/moon?useAffectedRows=true
    #url: jdbc:postgresql://192.168.20.83:5433/moon?useAffectedRows=true
    url: jdbc:postgresql://103.85.165.99:25432/moon?useAffectedRows=true
    username: postgres
    password: Postgres!_14_moon
    #password: postgres
@@ -130,7 +131,7 @@
  # IIS的主机地址
  iisHost: 127.0.0.1
  # FME服务地址
  fmeUrl: http://192.168.20.205:88/
  fmeUrl: http://127.0.0.1:88/
  # 出图服务
  exportServer: http://127.0.0.1/ExportMap
  #exportServer: http://192.168.20.83:80/ExportMap