From 88748094ae17ca3b6423c54d307f0d5c40c8f420 Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期六, 02 八月 2025 14:44:13 +0800
Subject: [PATCH] 增加文件完整性校验

---
 blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java |   84 +++++++++++++++++++++++------------------
 1 files changed, 47 insertions(+), 37 deletions(-)

diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java
index a4593ff..085a2a3 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java
@@ -12,14 +12,10 @@
 import org.springblade.core.oss.OssTemplate;
 import org.springblade.core.oss.model.BladeFile;
 import org.springblade.core.tool.api.IResultCode;
-import org.springblade.core.tool.api.ResultCode;
 import org.springblade.core.tool.utils.Func;
-import org.springblade.core.tool.utils.NumberUtil;
 import org.springblade.mdm.flow.entity.FlowProgramFile;
 import org.springblade.mdm.flow.mapper.FlowProgramFileMapper;
 import org.springblade.mdm.flow.vo.ProgramUploadVO;
-import org.springblade.mdm.program.entity.NcProgram;
-import org.springblade.mdm.program.service.ProcessProgRefService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.web.multipart.MultipartFile;
@@ -28,7 +24,6 @@
 import java.io.InputStream;
 import java.nio.charset.StandardCharsets;
 import java.util.List;
-import java.util.Map;
 
 /**
  * 娴佺▼绋嬪簭澶勭悊锛屽寘鎷笂浼狅紝鏌ヨ灞曠ず
@@ -47,49 +42,27 @@
 
 	public void uploadFlowProgramFile(ProgramUploadVO uploadVO) {
 
-		//Map<String, Object> vars = runtimeService.getVariables(uploadVO.getProcessInstanceId());
-
 		FlowProgramProperties progProps= flowCommonService.getProgramProperties(uploadVO.getProcessInstanceId());
-		checkFilenames(uploadVO.getFiles(),progProps);
+		MultipartFile file = uploadVO.getFile();
+		checkFilename(file.getOriginalFilename(),progProps);
 
 		String programName = getProgramName(progProps);
-		for(MultipartFile file : uploadVO.getFiles()) {
-			BladeFile bfile = ossTemplate.putFile(file);
 
-			FlowProgramFile progFile = new FlowProgramFile();
-			progFile.setName(file.getOriginalFilename());
-			progFile.setOssName(bfile.getName());
-			progFile.setProcessInstanceId(uploadVO.getProcessInstanceId());
+		BladeFile bfile = ossTemplate.putFile(file);
 
-			progFile.setProgramName(programName);
+		FlowProgramFile progFile = new FlowProgramFile();
+		progFile.setName(file.getOriginalFilename());
+		progFile.setOssName(bfile.getName());
+		progFile.setProcessInstanceId(uploadVO.getProcessInstanceId());
 
-			save(progFile);
-		}
-		//
-		//BladeFile bfile = ossTemplate.putFile(uploadVO.getFile());
-		//String link = bfile.getLink();
-		//淇濆瓨profame
-		/*
-		NcProgram prog = new NcProgram();
-		prog.setCode(generageCode());
-		prog.setName(file.getOriginalFilename());
-		prog.setNcNodeId(uploadVO.getNodeId());
-		prog.setOssName(bfile.getName());
-		prog.setDrawingNo(uploadVO.getDrawingNo());
-		prog.setProcessEdition(uploadVO.getProcessEdition());
-		prog.setIsLastEdition(1);
+		progFile.setProgramName(programName);
 
-		 */
+		save(progFile);
+
 	}
 
 	String getProgramName(FlowProgramProperties progProps){
 		return progProps.getDrawingNo()+"-"+progProps.getProcessNo();
-	}
-
-	public void checkFilenames(MultipartFile[] files,FlowProgramProperties programProperties){
-		for (MultipartFile file : files){
-			checkFilename(file.getOriginalFilename(),programProperties);
-		}
 	}
 
 	/**
@@ -197,5 +170,42 @@
 		return result;
 	}
 
+	/**
+	 * 楠岃瘉绋嬪簭鏂囦欢鐨勫畬鏁存�э紝浠呭湪缂栧埗鑺傜偣浣跨敤
+	 * @param processInstanceId 娴佺▼瀹炰緥id
+	 */
+	public void checkProgramFiles(String processInstanceId,boolean isPass) {
+		List<FlowProgramFile> flowPrograms = this.lambdaQuery().eq(FlowProgramFile::getProcessInstanceId, processInstanceId).orderByAsc(FlowProgramFile::getCreateTime).list();
+		if(isPass && flowPrograms.isEmpty()){
+			throw new ServiceException("璇蜂笂浼犵▼搴忔枃浠�");
+		}
+		int totalSeg = 0;
+		if(!flowPrograms.isEmpty()){
+			FlowProgramFile progFile = flowPrograms.get(0);
+			totalSeg = getProgramSegCount(progFile.getName());
+		}
 
+		if(totalSeg != flowPrograms.size()){
+			throw new ServiceException("搴斾笂浼�"+totalSeg+"娈电▼搴忥紝瀹為檯涓婁紶"+flowPrograms.size()+"娈�");
+		}
+
+	}
+
+	/**
+	 * 鏍规嵁鏂囦欢鍚嶈幏鍙栫▼搴忔�绘鏍�
+	 * @param filename 鏂囦欢鍚�
+	 * @return
+	 */
+	int getProgramSegCount(String filename){
+		int idx = filename.lastIndexOf(".");
+		String tempstr = filename.substring(0,idx);//鍘绘帀鎵╁睍鍚�
+		//System.out.println(tempstr);
+		idx = tempstr.lastIndexOf("-");
+		tempstr = tempstr.substring(0,idx);
+		//System.out.println(tempstr);
+		idx = tempstr.lastIndexOf("-");
+		tempstr = tempstr.substring(idx+1);
+		//System.out.println(tempstr);
+		return Func.toInt(tempstr);
+	}
 }

--
Gitblit v1.9.3