From 16dbf4a7062e0a228ebde98e1eaedd7a499b9b1d Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期三, 06 五月 2026 15:43:13 +0800
Subject: [PATCH] refactor(procurement): 优化库存记录方法调用

---
 src/main/java/com/ruoyi/project/common/CommonController.java |  209 +++++++++++++---------------------------------------
 1 files changed, 52 insertions(+), 157 deletions(-)

diff --git a/src/main/java/com/ruoyi/project/common/CommonController.java b/src/main/java/com/ruoyi/project/common/CommonController.java
index f4ca6ca..093e132 100644
--- a/src/main/java/com/ruoyi/project/common/CommonController.java
+++ b/src/main/java/com/ruoyi/project/common/CommonController.java
@@ -1,18 +1,20 @@
 package com.ruoyi.project.common;
 
 import com.ruoyi.basic.service.StorageBlobService;
+import com.ruoyi.basic.utils.FileUtil;
 import com.ruoyi.framework.aspectj.lang.annotation.Anonymous;
-import com.ruoyi.framework.config.ServerConfig;
 import com.ruoyi.framework.web.domain.R;
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiOperation;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.servlet.http.HttpServletResponse;
 import lombok.AllArgsConstructor;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import org.springframework.core.io.FileSystemResource;
+import org.springframework.http.ContentDisposition;
+import org.springframework.http.MediaType;
+import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
-import jakarta.servlet.http.HttpServletResponse;
 import java.io.File;
 import java.net.URLEncoder;
 import java.nio.charset.StandardCharsets;
@@ -24,179 +26,72 @@
  *
  * @author ruoyi
  */
-@Api(tags = "閫氱敤鎺ュ彛")
+@Tag(name = "閫氱敤鎺ュ彛")
 @AllArgsConstructor
 @RestController
 @RequestMapping("/common")
 public class CommonController {
-    private static final Logger log = LoggerFactory.getLogger(CommonController.class);
 
-    private ServerConfig serverConfig;
-
-    private static final String FILE_DELIMETER = ",";
 
     private final StorageBlobService storageBlobService;
-
-
-//    /**
-//     * 閫氱敤涓嬭浇璇锋眰
-//     *
-//     * @param fileName 鏂囦欢鍚嶇О
-//     * @param delete 鏄惁鍒犻櫎
-//     */
-//    @GetMapping("/download")
-//    public void fileDownload(String fileName, Boolean delete, HttpServletResponse response, HttpServletRequest request)
-//    {
-//        try
-//        {
-//            if (!FileUtils.checkAllowDownload(fileName))
-//            {
-//                throw new Exception(StringUtils.format("鏂囦欢鍚嶇О({})闈炴硶锛屼笉鍏佽涓嬭浇銆� ", fileName));
-//            }
-//            String realFileName =  fileName.substring(fileName.indexOf("_") + 1);
-//
-//            response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
-//            FileUtils.setAttachmentResponseHeader(response, realFileName);
-//            FileUtils.writeBytes(fileName, response.getOutputStream());
-
-    /// /            if (delete)
-    /// /            {
-    /// /                FileUtils.deleteFile(fileName);
-    /// /            }
-//        }
-//        catch (Exception e)
-//        {
-//            log.error("涓嬭浇鏂囦欢澶辫触", e);
-//        }
-//    }
-//
-//    /**
-//     * minio閫氱敤涓婁紶璇锋眰锛堝涓級
-//     */
-//    @PostMapping("/minioUploads")
-//    @ApiOperation(value = "minio閫氱敤涓婁紶璇锋眰")
-//    public AjaxResult minioUploadFiles(List<MultipartFile> files, String bucketName, Long type) throws Exception
-//    {
-//        return AjaxResult.success();
-//    }
-//
-//    /**
-//     * 閫氱敤涓婁紶璇锋眰锛堝崟涓級
-//     */
-//    @PostMapping("/upload")
-//    public AjaxResult uploadFile(MultipartFile file) throws Exception
-//    {
-//        try
-//        {
-//            // 涓婁紶鏂囦欢璺緞
-//            String filePath = RuoYiConfig.getUploadPath();
-//            // 涓婁紶骞惰繑鍥炴柊鏂囦欢鍚嶇О
-//            String fileName = FileUploadUtils.upload(filePath, file);
-//            String url = serverConfig.getUrl() + fileName;
-//            AjaxResult ajax = AjaxResult.success();
-//            ajax.put("url", url);
-//            ajax.put("fileName", fileName);
-//            ajax.put("newFileName", FileUtils.getName(fileName));
-//            ajax.put("originalFilename", file.getOriginalFilename());
-//            return ajax;
-//        }
-//        catch (Exception e)
-//        {
-//            return AjaxResult.error(e.getMessage());
-//        }
-//    }
-//
-//    /**
-//     * 閫氱敤涓婁紶璇锋眰锛堝涓級
-//     */
-//    @PostMapping("/uploads")
-//    public AjaxResult uploadFiles(List<MultipartFile> files) throws Exception
-//    {
-//        try
-//        {
-//            // 涓婁紶鏂囦欢璺緞
-//            String filePath = RuoYiConfig.getUploadPath();
-//            List<String> urls = new ArrayList<String>();
-//            List<String> fileNames = new ArrayList<String>();
-//            List<String> newFileNames = new ArrayList<String>();
-//            List<String> originalFilenames = new ArrayList<String>();
-//            for (MultipartFile file : files)
-//            {
-//                // 涓婁紶骞惰繑鍥炴柊鏂囦欢鍚嶇О
-//                String fileName = FileUploadUtils.upload(filePath, file);
-//                String url = serverConfig.getUrl() + fileName;
-//                urls.add(url);
-//                fileNames.add(fileName);
-//                newFileNames.add(FileUtils.getName(fileName));
-//                originalFilenames.add(file.getOriginalFilename());
-//            }
-//            AjaxResult ajax = AjaxResult.success();
-//            ajax.put("urls", StringUtils.join(urls, FILE_DELIMETER));
-//            ajax.put("fileNames", StringUtils.join(fileNames, FILE_DELIMETER));
-//            ajax.put("newFileNames", StringUtils.join(newFileNames, FILE_DELIMETER));
-//            ajax.put("originalFilenames", StringUtils.join(originalFilenames, FILE_DELIMETER));
-//            return ajax;
-//        }
-//        catch (Exception e)
-//        {
-//            return AjaxResult.error(e.getMessage());
-//        }
-//    }
-//
-//    /**
-//     * 鏈湴璧勬簮閫氱敤涓嬭浇
-//     */
-//    @GetMapping("/download/resource")
-//    public void resourceDownload(String resource, HttpServletRequest request, HttpServletResponse response)
-//            throws Exception
-//    {
-//        try
-//        {
-//            if (!FileUtils.checkAllowDownload(resource))
-//            {
-//                throw new Exception(StringUtils.format("璧勬簮鏂囦欢({})闈炴硶锛屼笉鍏佽涓嬭浇銆� ", resource));
-//            }
-//            // 鏈湴璧勬簮璺緞
-//            String localPath = RuoYiConfig.getProfile();
-//            // 鏁版嵁搴撹祫婧愬湴鍧�
-//            String downloadPath = localPath + StringUtils.substringAfter(resource, Constants.RESOURCE_PREFIX);
-//            // 涓嬭浇鍚嶇О
-//            String downloadName = StringUtils.substringAfterLast(downloadPath, "/");
-//            response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
-//            FileUtils.setAttachmentResponseHeader(response, downloadName);
-//            FileUtils.writeBytes(downloadPath, response.getOutputStream());
-//        }
-//        catch (Exception e)
-//        {
-//            log.error("涓嬭浇鏂囦欢澶辫触", e);
-//        }
-//    }
+    private final FileUtil fileUtil;
 
     @PostMapping({"/upload"})
-    @ApiOperation(value = "鏂囦欢涓婁紶")
-    public R upload(@RequestParam("files") List<MultipartFile> files) throws Exception {
-        return R.ok(storageBlobService.upload(files));
+    @Operation(summary = "鏂囦欢涓婁紶")
+    public R upload(@RequestParam("files") List<MultipartFile> files) {
+        return R.ok(storageBlobService.upload(files, false));
     }
 
+    /**
+     * 鍏叡鏂囦欢涓婁紶
+     * 姝ゆ帴鍙d笂浼犵殑鏂囦欢姘镐箙鏈夋晥锛屾厧鐢�
+     */
+    @PostMapping({"/public/upload"})
+    @Operation(summary = "鏂囦欢涓婁紶")
+    public R publicUpload(@RequestParam("files") List<MultipartFile> files) {
+        return R.ok(storageBlobService.upload(files, true));
+    }
 
     @GetMapping("/download/{fileName}")
     @Anonymous
-    public void download(@PathVariable String fileName, @RequestParam("token") String token, HttpServletResponse response) throws Exception {
-        File file = storageBlobService.getFileByToken(fileName, token);
+    public void download(@PathVariable String fileName,
+                         @RequestParam(value = "token", required = false) String token,
+                         @RequestParam(value = "publicKey", required = false) String publicKey,
+                         HttpServletResponse response) throws Exception {
+        File file;
+        if (publicKey != null) {
+            file = fileUtil.compressFile(storageBlobService.getPublicFile(fileName, publicKey));
+        } else {
+            file = fileUtil.compressFile(storageBlobService.getFileByToken(fileName, token));
+        }
         String originalFileName = storageBlobService.getDownloadFileName(fileName);
         String encodedFileName = URLEncoder.encode(originalFileName, StandardCharsets.UTF_8.name()).replace("+", "%20");
         response.setHeader("Content-Disposition", "attachment;filename*=UTF-8''" + encodedFileName);
+        response.setContentLengthLong(file.length());
         Files.copy(file.toPath(), response.getOutputStream());
     }
 
     @GetMapping("/preview/{fileName}")
     @Anonymous
-    public void preview(@PathVariable String fileName, @RequestParam("token") String token, HttpServletResponse response) throws Exception {
-        File file = storageBlobService.getFileByToken(fileName, token);
+    public ResponseEntity<FileSystemResource> preview(@PathVariable String fileName,
+                                                      @RequestParam(value = "token", required = false) String token,
+                                                      @RequestParam(value = "publicKey", required = false) String publicKey) throws Exception {
+        File file;
+        if (publicKey != null) {
+            file = fileUtil.compressFile(storageBlobService.getPublicFile(fileName, publicKey));
+        } else {
+            file = fileUtil.compressFile(storageBlobService.getFileByToken(fileName, token));
+        }
         String contentType = Files.probeContentType(file.toPath());
-        response.setContentType(contentType == null ? "application/octet-stream" : contentType);
-        String encodedFileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name()).replace("+", "%20");
-        response.setHeader("Content-Disposition", "inline;filename*=UTF-8''" + encodedFileName);
-        Files.copy(file.toPath(), response.getOutputStream());
+
+        ContentDisposition contentDisposition = ContentDisposition.inline()
+                .filename(fileName, StandardCharsets.UTF_8)
+                .build();
+
+        return ResponseEntity.ok()
+                .contentType(MediaType.parseMediaType(contentType != null ? contentType : "application/octet-stream"))
+                .contentLength(file.length())
+                .header("Content-Disposition", contentDisposition.toString())
+                .body(new FileSystemResource(file));
     }
 }

--
Gitblit v1.9.3