From 300cf495c6a708df63621ff70e6d5408abc2912a Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期一, 30 三月 2026 11:50:27 +0800
Subject: [PATCH] yys 转移设备代码

---
 src/main/java/com/ruoyi/other/controller/TempFileController.java |   85 +++++++++++++++++++++++++++++++++++++++---
 1 files changed, 79 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/ruoyi/other/controller/TempFileController.java b/src/main/java/com/ruoyi/other/controller/TempFileController.java
index 6834d13..d006ba3 100644
--- a/src/main/java/com/ruoyi/other/controller/TempFileController.java
+++ b/src/main/java/com/ruoyi/other/controller/TempFileController.java
@@ -1,13 +1,25 @@
 package com.ruoyi.other.controller;
 
 
+import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.framework.web.domain.AjaxResult;
 import com.ruoyi.other.service.TempFileService;
+import com.ruoyi.purchase.dto.ProductRecordDto;
+import com.ruoyi.purchase.dto.TicketRegistrationDto;
+import com.ruoyi.purchase.service.ITicketRegistrationService;
+import com.ruoyi.purchase.service.impl.TicketRegistrationServiceImpl;
+import io.swagger.annotations.ApiOperation;
 import lombok.AllArgsConstructor;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.MediaType;
+import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
 
 
 @RestController
@@ -17,13 +29,74 @@
 
     private TempFileService tempFileService;
 
+    private TicketRegistrationServiceImpl ticketRegistrationServiceImpl;
+
     @PostMapping("/upload")
-    public AjaxResult uploadFile(MultipartFile file) {
+    public AjaxResult uploadFile(MultipartFile file, Integer type) {
         try {
-            return AjaxResult.success(tempFileService.uploadFile(file));
-        }catch (Exception e) {
+            return AjaxResult.success(tempFileService.uploadFile(file, type));
+        } catch (Exception e) {
             return AjaxResult.error(e.getMessage());
         }
     }
 
+    @PostMapping("uploadFile")
+    public AjaxResult uploadFile(@RequestBody ProductRecordDto productRecordDto) {
+        try {
+            if (!productRecordDto.getTempFileIds().isEmpty()&&productRecordDto.getTicketRegistrationId() != null) {
+                ticketRegistrationServiceImpl.migrateTempFilesToFormal(productRecordDto.getTicketRegistrationId(), productRecordDto.getTempFileIds());
+            }
+        } catch (Exception e) {
+            return AjaxResult.error(e.getMessage());
+        }
+        return AjaxResult.success();
+    }
+
+    /**
+     * 鍥剧墖棰勮锛堟牴鎹鐩樿矾寰勶級
+     */
+    @GetMapping("/preview")
+    @ApiOperation(value = "鍥剧墖棰勮")
+    public void previewImage(String url, HttpServletResponse response) {
+        if (!StringUtils.hasText(url)) {
+            response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
+            return;
+        }
+        try {
+            Path filePath = Paths.get(url);
+            if (!Files.exists(filePath) || !Files.isRegularFile(filePath)) {
+                response.setStatus(HttpServletResponse.SC_NOT_FOUND);
+                return;
+            }
+            String filename = filePath.getFileName().toString();
+            String ext = filename.contains(".") ? filename.substring(filename.lastIndexOf('.') + 1).toLowerCase() : "";
+            MediaType mediaType;
+            switch (ext) {
+                case "png":
+                    mediaType = MediaType.IMAGE_PNG;
+                    break;
+                case "gif":
+                    mediaType = MediaType.IMAGE_GIF;
+                    break;
+                case "bmp":
+                    mediaType = MediaType.parseMediaType("image/bmp");
+                    break;
+                case "webp":
+                    mediaType = MediaType.parseMediaType("image/webp");
+                    break;
+                case "jpg":
+                case "jpeg":
+                    mediaType = MediaType.IMAGE_JPEG;
+                    break;
+                default:
+                    mediaType = MediaType.APPLICATION_OCTET_STREAM;
+            }
+            response.setContentType(mediaType.toString());
+            response.setHeader(HttpHeaders.CACHE_CONTROL, "max-age=3600");
+            Files.copy(filePath, response.getOutputStream());
+        } catch (IOException e) {
+            response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
+        }
+    }
+
 }

--
Gitblit v1.9.3