From 72e6bac02526caebc3797a7c2934d12896805708 Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期二, 23 九月 2025 00:47:18 +0800
Subject: [PATCH] 修复文件状态读取问题
---
blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/FlowProgramFileService.java | 43 ++++++++++++++++++++++++++++++++++++++-----
1 files changed, 38 insertions(+), 5 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 48f83b5..b52bfbf 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,8 +12,11 @@
import org.springblade.core.mp.base.BizServiceImpl;
import org.springblade.core.oss.OssTemplate;
import org.springblade.core.oss.model.BladeFile;
+import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.core.tool.api.IResultCode;
import org.springblade.core.tool.utils.Func;
+import org.springblade.core.tool.utils.UrlUtil;
+import org.springblade.mdm.commons.service.OssFileCommonService;
import org.springblade.mdm.flow.entity.FlowProgramFile;
import org.springblade.mdm.flow.mapper.FlowProgramFileMapper;
import org.springblade.mdm.flow.vo.ProgramUploadVO;
@@ -41,7 +44,7 @@
@Autowired
private OssTemplate ossTemplate;
@Autowired
- private RuntimeService runtimeService;
+ private OssFileCommonService ossFileCommonService;
@Autowired
private FlowCommonService flowCommonService;
@@ -56,6 +59,10 @@
if(file.getSize() == 0){
throw new ServiceException("绋嬪簭鏂囦欢涓嶅彲涓虹┖鏂囦欢");
}
+ if(exists(file.getOriginalFilename(),uploadVO.getProcessInstanceId())){
+ throw new ServiceException("鍚屽悕鏂囦欢宸插瓨鍦細"+file.getOriginalFilename());
+ }
+
if(FlowProgramFile.TYPE_PROGRAM.equals(uploadVO.getFileType())) {
ProgramFileNameCheckUtil.checkFilename(file.getOriginalFilename(), progProps);
}
@@ -66,13 +73,21 @@
progFile.setName(file.getOriginalFilename());
progFile.setOssName(bfile.getName());
progFile.setProcessInstanceId(uploadVO.getProcessInstanceId());
- progFile.setProgramName(NcNodeService.genProgramName(progProps.getDrawingNo(),progProps.getProcessNo()));
+ progFile.setProgramName(NcNodeService.genProgramName(progProps.getDrawingNo(),progProps.getProcessNo(),progProps.getProcessEdition()));
progFile.setFileType(uploadVO.getFileType());
save(progFile);
}
-
+ /**
+ * 鍒ゆ柇閭f祦绋嬩笅鏄惁鏈夊悓鍚嶉棶棰�
+ * @param filename 鏂囦欢鍚�
+ * @param processInstanceId 娴佺▼瀹炰緥id
+ * @return 鏄惁
+ */
+ boolean exists(String filename,String processInstanceId){
+ return lambdaQuery().eq(FlowProgramFile::getName, filename).eq(FlowProgramFile::getProcessInstanceId, processInstanceId).count()>0;
+ }
/**
* 鑾峰彇鏂囦欢鍐呭
* @param id 鏂囦欢id
@@ -126,12 +141,30 @@
}
+ /**
+ * 娴佺▼鏂囦欢涓嬭浇
+ * @param id 娴佺▼鏂囦欢id
+ * @param response http鍝嶅簲
+ * @throws IOException 鏂囦欢鎿嶄綔寮傚父
+ */
public void download(Long id, HttpServletResponse response) throws IOException {
FlowProgramFile flowFile = this.getById(id);
- response.setHeader("Content-Disposition", "attachment; filename="+flowFile.getName());
+ ossFileCommonService.download(flowFile.getOssName(),flowFile.getName(),response);
+ /*
+ response.setHeader("Content-Disposition", "attachment; filename="+ UrlUtil.encode(flowFile.getName()));
response.setContentType("application/octet-stream");
try(InputStream ins = ossTemplate.statFileStream(flowFile.getOssName());){
IOUtils.copy(ins,response.getOutputStream());
- }
+ }*/
+ }
+
+ /**
+ * 鑾峰彇鍏充簬娴佺▼鐨勬墍鏈夋枃浠�
+ * @param processInstanceId 娴佺▼瀹炰緥id
+ * @return 娴佺▼鍏宠仈鐨勬枃浠跺垪琛�
+ */
+ public List<FlowProgramFile> listByProcessInstanceId(String processInstanceId){
+ return lambdaQuery()
+ .eq(FlowProgramFile::getProcessInstanceId, processInstanceId).list();
}
}
--
Gitblit v1.9.3