From ed8c7a5effd0d423ce1118b680ecdca6fe732609 Mon Sep 17 00:00:00 2001
From: 13693261870 <252740454@qq.com>
Date: 星期三, 02 七月 2025 16:43:13 +0800
Subject: [PATCH] Merge branch 'master' of http://192.168.11.205:9000/r/P2022036_Service

---
 src/main/java/com/lf/server/service/all/UploadAttachService.java |   94 +++++++++++++++++++++++++++-------------------
 1 files changed, 55 insertions(+), 39 deletions(-)

diff --git a/src/main/java/com/lf/server/service/all/UploadAttachService.java b/src/main/java/com/lf/server/service/all/UploadAttachService.java
index ab48101..062f2c6 100644
--- a/src/main/java/com/lf/server/service/all/UploadAttachService.java
+++ b/src/main/java/com/lf/server/service/all/UploadAttachService.java
@@ -14,7 +14,9 @@
 import com.lf.server.mapper.data.DownloadMapper;
 import com.lf.server.service.sys.AttachService;
 import net.lingala.zip4j.ZipFile;
+import net.lingala.zip4j.model.FileHeader;
 import net.lingala.zip4j.model.ZipParameters;
+import org.apache.commons.io.FileUtils;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -43,7 +45,7 @@
 
     private static String tabs = "''";
 
-    private final static Map<String, String> ATTACH_TABS = new HashMap<>();
+    public final static Map<String, String> ATTACH_TABS = new HashMap<>();
 
     private final static Log log = LogFactory.getLog(UploadAttachService.class);
 
@@ -267,27 +269,38 @@
             return 0;
         }
 
-        Field field = getAnnexField(list.get(0), meta);
+        Field field = getAnnexField(list.get(0), meta.getTab());
         String folder = meta.getName().split("\\.")[0].trim().toLowerCase() + File.separator;
 
         int rows = 0;
         for (Object obj : list) {
-            String name = getAnnexName(obj, field);
-            if (StringHelper.isEmpty(name)) {
+            String[] names = getNames(getAnnexName(obj, field));
+            if (null == names || names.length == 0) {
                 continue;
             }
 
-            String file = findAnnexFile(name, folder, files);
-            if (null == file) {
-                continue;
-            }
+            for (String name : names) {
+                String file = findAnnexFile(name, folder, files);
+                if (null == file) {
+                    continue;
+                }
 
-            BaseEntity be = (BaseEntity) obj;
-            rows += insertXlsAnnex(ue, meta, be, file);
-            files.remove(file);
+                rows += insertXlsAnnex(ue, meta, (BaseEntity) obj, file);
+            }
         }
 
         return rows;
+    }
+
+    /**
+     * 鑾峰彇鍚嶇О
+     */
+    public static String[] getNames(String str) {
+        if (StringHelper.isEmpty(str)) {
+            return null;
+        }
+
+        return str.replace("锛�", ",").replace("锛�", ",").split(",");
     }
 
     /**
@@ -317,9 +330,9 @@
     /**
      * 鑾峰彇闄勪欢瀛楁
      */
-    private Field getAnnexField(Object obj, MetaEntity meta) {
+    public static Field getAnnexField(Object obj, String tab) {
         try {
-            String str = ATTACH_TABS.get(meta.getTab());
+            String str = ATTACH_TABS.get(tab);
 
             Field field = obj.getClass().getDeclaredField(str);
             field.setAccessible(true);
@@ -333,7 +346,7 @@
     /**
      * 鑾峰彇闄勪欢鍚嶇О
      */
-    private String getAnnexName(Object obj, Field field) {
+    public static String getAnnexName(Object obj, Field field) {
         try {
             Object val = field.get(obj);
 
@@ -374,7 +387,6 @@
         String md5 = FileHelper.getFileMd5(file);
         AttachEntity old = attachService.selectByTabAndGuid(meta.getTab(), be.getEventid(), md5);
         if (null != old) {
-            f.delete();
             return 0;
         }
 
@@ -384,10 +396,13 @@
         AttachEntity ae = getAttachEntity(ue, meta.getTab(), be.getEventid(), fileName, md5, sizes);
         String targetPath = pathHelper.getConfig().getUploadPath() + File.separator + ae.getPath();
 
-        f.renameTo(new File(targetPath));
-        int rows = attachService.insert(ae);
+        try {
+            FileUtils.copyFile(f, new File(targetPath));
+        } catch (Exception ex) {
+            log.error(ex.getMessage(), ex);
+        }
 
-        return rows > 0 ? 1 : 0;
+        return attachService.insert(ae);
     }
 
     /**
@@ -412,7 +427,7 @@
     /**
      * 璇锋眰涓嬭浇
      */
-    public String downloadReqForGuids(UserEntity ue, String[] guids) {
+    public String downloadReqForGuids(UserEntity ue, List<String> guids) {
         List<AttachEntity> list = attachService.selectByGuids(guids);
 
         return downloadReq(ue, list);
@@ -421,7 +436,7 @@
     /**
      * 璇锋眰涓嬭浇
      */
-    public String downloadReqForTabGuids(UserEntity ue, String tab, String[] guids) {
+    public String downloadReqForTabGuids(UserEntity ue, String tab, List<String> guids) {
         List<AttachEntity> list = attachService.selectByTabGuids(tab, guids);
 
         return downloadReq(ue, list);
@@ -435,20 +450,12 @@
             return null;
         }
 
-        String tempName = StringHelper.YMDHMS2_FORMAT.format(new Date());
-        String filePath = pathHelper.getTempPath(tempName) + File.separator + tempName;
-
-        File file = new File(filePath);
-        if (file.exists() && file.isDirectory()) {
-            FileHelper.deleteDir(filePath);
-        }
-
-        String zipName = tempName + ".zip";
+        String zipName = StringHelper.YMDHMS2_FORMAT.format(new Date()) + ".zip";
         String zipFile = pathHelper.getDownloadFullPath() + File.separator + zipName;
 
         ZipFile zip = Zip4jHelper.createZipFile(zipFile, null);
-        ZipParameters params = Zip4jHelper.getZipParams();
-        addZipFiles(zip, params, file.listFiles());
+        ZipParameters params = Zip4jHelper.getZipParams(false);
+        addZipFiles(zip, params, list);
 
         DownloadEntity downloadEntity = getDownloadEntity(ue, zipFile, null);
         int rows = downloadMapper.insert(downloadEntity);
@@ -459,14 +466,23 @@
     /**
      * 娣诲姞Zip鏂囦欢
      */
-    private void addZipFiles(ZipFile zip, ZipParameters params, File[] files) {
-        if (null == files || files.length == 0) {
-            return;
-        }
-
-        for (File f : files) {
+    private void addZipFiles(ZipFile zip, ZipParameters params, List<AttachEntity> list) {
+        int i = 1;
+        String uploadPath = pathHelper.getConfig().getUploadPath();
+        for (AttachEntity ae : list) {
             try {
-                zip.addFile(f, params);
+                String filePath = uploadPath + File.separator + ae.getPath();
+
+                File file = new File(filePath);
+                if (!file.exists() || file.isDirectory()) {
+                    continue;
+                }
+
+                zip.addFile(file, params);
+                FileHeader header = zip.getFileHeader(file.getName());
+                if (null != header) {
+                    zip.renameFile(header, i + "_" + ae.getName());
+                }
             } catch (Exception ex) {
                 log.error(ex.getMessage(), ex);
             }
@@ -479,7 +495,7 @@
     private DownloadEntity getDownloadEntity(UserEntity ue, String file, String pwd) {
         DownloadEntity de = new DownloadEntity();
         de.setName(FileHelper.getFileName(file));
-        // 1-Shp鏂囦欢锛�2-涓撻鍥撅紝3-鍏冩暟鎹紝4-涓氬姟鏁版嵁锛�5-绠¢亾鍒嗘瀽锛�6-缁熻鎶ュ憡锛�7-闄勪欢
+        // 1-Shp鏂囦欢锛�2-涓撻鍥撅紝3-鍏冩暟鎹紝4-涓氬姟鏁版嵁锛�5-绠¢亾鍒嗘瀽锛�6-缁熻鎶ュ憡锛�7-闄勪欢鏂囦欢锛�8-鐡︾墖鏂囦欢
         de.setType(7);
         de.setSizes(FileHelper.sizeToMb(new File(file).length()));
         de.setDepid(ue.getDepid());

--
Gitblit v1.9.3