From 254a64e2a3b773e6f743c179916db2c8c31ff140 Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期一, 18 八月 2025 19:17:17 +0800
Subject: [PATCH] 处理其他文件在固化后消失的问题

---
 blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/service/DNCSendBackService.java |   27 +++++++++++++++++++++++----
 1 files changed, 23 insertions(+), 4 deletions(-)

diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/service/DNCSendBackService.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/service/DNCSendBackService.java
index 5fbf450..4e00615 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/service/DNCSendBackService.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/service/DNCSendBackService.java
@@ -20,6 +20,7 @@
 import org.springblade.mdm.flow.service.CureFlowService;
 import org.springblade.mdm.flow.service.FlowCommonService;
 import org.springblade.mdm.flow.service.FlowProgramFileService;
+import org.springblade.mdm.program.entity.DncBackFile;
 import org.springblade.mdm.program.entity.NcNode;
 import org.springblade.mdm.program.entity.NcProgramExchange;
 import org.springblade.mdm.program.mapper.NcProgramExchangeMapper;
@@ -56,7 +57,8 @@
 	private final OssTemplate ossTemplate;
 	private final BladeRedis bladeRedis;
 	private final FlowCommonService flowCommonService;
-
+	private final DncBackFileService dncBackFileService;
+	private final ProgramFlowStatusQueryService programFlowStatusQueryService;
 	private String getFileKey(){
 		return "dncimpfile-"+ AuthUtil.getUserId();
 	}
@@ -210,6 +212,13 @@
 
 	}
 
+	/**
+	 * 澶勭悊鍥炰紶鏂囦欢
+	 * @param ossFileName
+	 * @param acceptIdList
+	 * @return
+	 * @throws IOException
+	 */
 	private Map<Long, List<FlowProgramFile>> dealWithBackFile(String ossFileName, List<Long> acceptIdList) throws IOException{
 		Map<Long, List<FlowProgramFile>> pkgIdFileMap = new HashMap<>();
 
@@ -246,8 +255,14 @@
 				//鏍规嵁鑺傜偣淇℃伅鏌ヨ娴佺▼
 				boolean active = flowCommonService.isProcessInstanceActive(packageNode.getProcessInstanceId());
 				if(active){
-					throw new ServiceException(programPackageName+"姝e湪瀹℃壒涓紝璇峰嬁閲嶅鍏ュ簱銆�");
+					throw new ServiceException(programPackageName+"姝e湪瀹℃壒涓紝璇峰嬁绛夊緟瀹℃壒瀹屾垚銆�");
 				}
+
+				//楠岃瘉閮借繃浜嗭紝淇濆瓨dncbackFile
+				DncBackFile backFile = new DncBackFile();
+				backFile.setNcNodeId(packageNode.getId());
+				backFile.setOssName(ossFileName);
+				dncBackFileService.save(backFile);
 
 				List<FlowProgramFile> flowFiles = new ArrayList<>();
 				//鏌ユ壘鍖呬笅鐨勬枃浠舵暟鎹�,
@@ -291,6 +306,7 @@
 	 * @param programPackageSubMap 鏂扮殑 绋嬪簭鍖呰妭鐐筰d -> =鏂囦欢鍒楄〃 map锛岀敤浜庡洖浼犳暟鎹�
 	 * @throws IOException 璁块棶鏂囦欢寮傚父
 	 */
+	/*
 	List<NcNode> updateNodeDataByDNCBackData(String pkgFileName, List<Long> programPackageIdList,Map<Long,List<NcNode>> programPackageSubMap) throws IOException {
 		InputStream inputStream = this.ossTemplate.statFileStream(pkgFileName);
 		Path tempZipFile = createTempFile(inputStream);
@@ -391,7 +407,7 @@
 
 		return newProgramPackageNodeList;
 	}
-
+	*/
 	/**
 	 * 鍒涘缓涓�涓复鏃秡ip鏂囦欢
 	 * @param inputStream 鏂囦欢鐨勮緭鍏ユ祦
@@ -428,7 +444,10 @@
 					}
 					try (InputStream fileIns = zipFile.getInputStream(zipFile.getEntry(entryName))) {
 						ByteArrayInputStream bos = new ByteArrayInputStream(fileIns.readAllBytes());
-						boolean isText = FileContentUtil.isTextFile(bos);
+						boolean isText = StringUtils.endsWithIgnoreCase(entryName,".txt") || StringUtils.endsWithIgnoreCase(entryName,".nc")|| StringUtils.endsWithIgnoreCase(entryName,".xml");
+						if(!isText) {
+							isText = FileContentUtil.isTextFile(bos);
+						}
 						if (isText) {
 							bos.reset();
 							result = FileContentUtil.getContentFromStream(bos);

--
Gitblit v1.9.3