From 344d9006faa27ea65e3eaf5e8f9173aad2266038 Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期三, 23 七月 2025 17:23:53 +0800
Subject: [PATCH] 2025.7.23 1. 动态溯源模块完成,发布

---
 src/main/kotlin/com/flightfeather/uav/lightshare/service/impl/MissionServiceImpl.kt |   20 +++++++++++++++++++-
 1 files changed, 19 insertions(+), 1 deletions(-)

diff --git a/src/main/kotlin/com/flightfeather/uav/lightshare/service/impl/MissionServiceImpl.kt b/src/main/kotlin/com/flightfeather/uav/lightshare/service/impl/MissionServiceImpl.kt
index a7a0458..e0f0d8a 100644
--- a/src/main/kotlin/com/flightfeather/uav/lightshare/service/impl/MissionServiceImpl.kt
+++ b/src/main/kotlin/com/flightfeather/uav/lightshare/service/impl/MissionServiceImpl.kt
@@ -13,6 +13,8 @@
 import com.github.pagehelper.PageHelper
 import org.springframework.stereotype.Service
 import tk.mybatis.mapper.entity.Example
+import java.io.File
+import java.util.*
 import javax.servlet.http.HttpServletResponse
 
 @Service
@@ -35,11 +37,18 @@
         return BaseResponse(true, head = DataHead(pageInfo.pageNum, pageInfo.pages),data = result)
     }
 
+    @Synchronized
     override fun createMission(mission: Mission): BaseResponse<Boolean> {
         missionMapper.selectByPrimaryKey(mission.missionCode)?.run {
             return BaseResponse(false, "浠诲姟缂栧彿宸插瓨鍦�")
         }
         missionMapper.insert(mission).let {
+            return BaseResponse(it == 1)
+        }
+    }
+
+    override fun updateMission(mission: Mission): BaseResponse<Boolean> {
+        missionMapper.updateByPrimaryKey(mission).let {
             return BaseResponse(it == 1)
         }
     }
@@ -61,6 +70,15 @@
     }
 
     override fun getReport(missionCode: String, response: HttpServletResponse) {
-        missionReport.execute(missionCode, FactorFilter.default())
+        val path = missionReport.execute(missionCode, FactorFilter.default())
+        val pathArr = path.split("/")
+        val file = File(path)
+        if (file.exists()) {
+            response.contentType = "application/vnd.ms-excel;charset=UTF-8"
+            val name = Base64.getEncoder().encodeToString(pathArr.last().toByteArray())
+            response.setHeader("fileName", name)
+            response.outputStream.write(file.readBytes())
+        }
+        return
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3