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 | 126 +++++++++++++++++++++++++++++++++-------- 1 files changed, 101 insertions(+), 25 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 ec0a2f4..062f2c6 100644 --- a/src/main/java/com/lf/server/service/all/UploadAttachService.java +++ b/src/main/java/com/lf/server/service/all/UploadAttachService.java @@ -4,13 +4,19 @@ import com.lf.server.controller.all.BaseController; import com.lf.server.entity.all.*; import com.lf.server.entity.ctrl.KeyValueEntity; +import com.lf.server.entity.data.DownloadEntity; import com.lf.server.entity.data.MetaEntity; import com.lf.server.entity.data.MetaFileEntity; import com.lf.server.entity.sys.AttachEntity; import com.lf.server.entity.sys.UserEntity; import com.lf.server.helper.*; import com.lf.server.mapper.all.BasicMapper; +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; @@ -20,10 +26,7 @@ import javax.servlet.http.HttpServletResponse; import java.io.File; import java.lang.reflect.Field; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; /** * 涓婁紶闄勪欢鏈嶅姟绫� @@ -37,9 +40,12 @@ @Autowired AttachService attachService; + @Autowired + DownloadMapper downloadMapper; + 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); @@ -263,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(","); } /** @@ -313,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); @@ -329,7 +346,7 @@ /** * 鑾峰彇闄勪欢鍚嶇О */ - private String getAnnexName(Object obj, Field field) { + public static String getAnnexName(Object obj, Field field) { try { Object val = field.get(obj); @@ -370,7 +387,6 @@ String md5 = FileHelper.getFileMd5(file); AttachEntity old = attachService.selectByTabAndGuid(meta.getTab(), be.getEventid(), md5); if (null != old) { - f.delete(); return 0; } @@ -380,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); } /** @@ -408,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); @@ -417,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); @@ -431,6 +450,63 @@ return null; } - return ""; + 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(false); + addZipFiles(zip, params, list); + + DownloadEntity downloadEntity = getDownloadEntity(ue, zipFile, null); + int rows = downloadMapper.insert(downloadEntity); + + return rows > 0 ? downloadEntity.getGuid() : null; + } + + /** + * 娣诲姞Zip鏂囦欢 + */ + private void addZipFiles(ZipFile zip, ZipParameters params, List<AttachEntity> list) { + int i = 1; + String uploadPath = pathHelper.getConfig().getUploadPath(); + for (AttachEntity ae : list) { + try { + 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); + } + } + } + + /** + * 鑾峰彇涓嬭浇瀹炰綋绫� + */ + 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-闄勪欢鏂囦欢锛�8-鐡︾墖鏂囦欢 + de.setType(7); + de.setSizes(FileHelper.sizeToMb(new File(file).length())); + de.setDepid(ue.getDepid()); + de.setDcount(0); + de.setPwd(pwd); + de.setUrl(FileHelper.getRelativePath(file)); + de.setDescr("闄勪欢鏂囦欢"); + de.setGuid(FileHelper.getFileMd5(file)); + de.setCreateUser(ue.getId()); + // de.setGeom(null) + + return de; } } -- Gitblit v1.9.3