From 67e380f8a481825084e6cf279a5de5adc9063136 Mon Sep 17 00:00:00 2001
From: rain <167982779@qq.com>
Date: Wed, 17 Apr 2024 09:36:34 +0800
Subject: [PATCH] 新增DB模块,将DB文件数据导入数据库,DB文件数据生成航线。新增成果展示,对图斑成果进行上传和删除。

---
 src/main/java/com/dji/sample/territory/controller/TbDkjbxxController.java |   74 ++++++++++++++++++++++++++++++++++--
 1 files changed, 69 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/dji/sample/territory/controller/TbDkjbxxController.java b/src/main/java/com/dji/sample/territory/controller/TbDkjbxxController.java
index 2ba53ae..a0f82bb 100644
--- a/src/main/java/com/dji/sample/territory/controller/TbDkjbxxController.java
+++ b/src/main/java/com/dji/sample/territory/controller/TbDkjbxxController.java
@@ -1,18 +1,43 @@
 package com.dji.sample.territory.controller;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.dji.sample.common.model.CustomClaim;
 import com.dji.sample.common.model.PaginationData;
 import com.dji.sample.common.model.ResponseResult;
+import com.dji.sample.common.util.MinioUrlUtils;
 import com.dji.sample.log.model.entity.DroneFlightLogEntity;
+import com.dji.sample.media.model.MediaFileEntity;
+import com.dji.sample.patches.dao.GetPatchesMapper;
+import com.dji.sample.patches.model.Param.PatchesParam;
+import com.dji.sample.patches.model.entity.LotInfo;
+import com.dji.sample.patches.service.GetPatchesService;
+import com.dji.sample.patches.service.ShpToDataSourceService;
+import com.dji.sample.patches.utils.GeoToolsUtil;
+import com.dji.sample.patches.utils.MultipartFileTOFileUtil;
+import com.dji.sample.patches.xml.mode.XMLTemplateModel;
+import com.dji.sample.patches.xml.utils.CreateWaylineFileUtils;
 import com.dji.sample.territory.model.entity.TbDkjbxxEntity;
 import com.dji.sample.territory.service.ITbDkjbxxService;
+import com.dji.sample.territory.service.ITbFJService;
+import com.dji.sample.wayline.model.entity.WaylineFileEntity;
+import com.dji.sample.wayline.service.IWaylineFileService;
 import lombok.extern.slf4j.Slf4j;
+import org.locationtech.jts.geom.Coordinate;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
 
+import javax.servlet.http.HttpServletRequest;
+import java.io.File;
+import java.io.IOException;
+import java.net.URL;
+import java.sql.SQLException;
+import java.util.Arrays;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
+
+import static com.dji.sample.component.AuthInterceptor.TOKEN_CLAIM;
 
 /**
  * @PROJECT_NAME: drone
@@ -27,6 +52,10 @@
 
     @Autowired
     private ITbDkjbxxService tbDkjbxxService;
+    @Autowired
+    private ShpToDataSourceService service;
+    @Autowired
+    private IWaylineFileService waylineFileService;
 
     @GetMapping("/list")
     public ResponseResult list() {
@@ -34,4 +63,39 @@
         return ResponseResult.success(list);
     }
 
-}
+    /**
+     * 上传文件并保存到数据库
+     * @param file 需要上传的文件,通过multipart/form-data方式提交
+     * @return 返回上传结果的ResponseResult对象,其中包含上传成功的消息
+     */
+    @PostMapping("/upload")
+    public ResponseResult<String> uploadFile(@RequestParam("file") MultipartFile file) {
+        tbDkjbxxService.uploadFile(file);
+        List<TbDkjbxxEntity> list = tbDkjbxxService.list();
+        service.savaInMysql(list);
+        return tbDkjbxxService.uploadFile(file);
+    }
+
+    @PostMapping("/uploadLot")
+    public ResponseResult getGeo(@RequestParam String workspaceId,
+                                 @RequestParam String waylineName,
+                                 @RequestParam double airportLat,
+                                 @RequestParam double airportLon,
+                                 HttpServletRequest request) throws Exception {
+        MultipartFile multipartFile = tbDkjbxxService.listFile(workspaceId, waylineName, airportLat, airportLon);
+        CustomClaim customClaim = (CustomClaim) request.getAttribute(TOKEN_CLAIM);
+        String creator = customClaim.getUsername();
+        waylineFileService.importKmzFileBack(multipartFile, workspaceId, creator);
+        WaylineFileEntity entity = waylineFileService.selectByName(waylineName);
+        Map<String, String> infoMap = new HashMap<>();
+        URL url = null;
+        try {
+            url = waylineFileService.getObjectUrl(workspaceId, entity.getWaylineId());
+            infoMap.put("url", String.valueOf(MinioUrlUtils.getUrl(url)));
+            infoMap.put("waylineId", entity.getWaylineId());
+        } catch (SQLException e) {
+            throw new RuntimeException(e);
+        }
+        return ResponseResult.success(infoMap);
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.3