From 9ea873a7ca323487baf158b5cb6c9e3fc8e4e7ec Mon Sep 17 00:00:00 2001 From: IT-xiaoXiong <774495953@qq.com> Date: Tue, 23 Nov 2021 19:04:56 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A6=82=E6=9E=9Cpdf=E6=98=AF=E5=8D=95?= =?UTF-8?q?=E6=96=87=E4=BB=B6=EF=BC=8C=E5=88=99=E4=B9=9F=E9=9C=80=E8=A6=81?= =?UTF-8?q?=E8=BF=9B=E8=A1=8C=E4=B8=80=E6=AC=A1=E6=96=87=E4=BB=B6=E5=A4=8D?= =?UTF-8?q?=E5=88=B6=EF=BC=8C=E4=BD=86=E6=98=AF=E4=B8=8D=E9=9C=80=E8=A6=81?= =?UTF-8?q?=E8=BF=9B=E8=A1=8C=E5=90=88=E5=B9=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../convert_pdf/ConvertPdfAction.java | 34 ++++++++++++++++--- 1 file changed, 30 insertions(+), 4 deletions(-) diff --git a/weaver/aiyh_pcn/convert_pdf/ConvertPdfAction.java b/weaver/aiyh_pcn/convert_pdf/ConvertPdfAction.java index 33f4898..8f13d95 100644 --- a/weaver/aiyh_pcn/convert_pdf/ConvertPdfAction.java +++ b/weaver/aiyh_pcn/convert_pdf/ConvertPdfAction.java @@ -4,13 +4,19 @@ import aiyh.utils.Util; import aiyh.utils.mapUtil.ParaMap; import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl; import aiyh.utils.zwl.common.ToolUtil; +import org.apache.axiom.util.base64.Base64Utils; +import org.apache.commons.io.IOUtils; import org.h2.util.StringUtils; import weaver.conn.RecordSet; import weaver.docs.docs.seconddev.CreateDocForJSGJXT; +import weaver.file.ImageFileManager; import weaver.hrm.User; import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.FileProcessor; import weaver.soa.workflow.request.RequestInfo; +import java.io.IOException; +import java.io.InputStream; import java.util.Map; /** @@ -67,9 +73,7 @@ public class ConvertPdfAction implements Action { if(StringUtils.isNullOrEmpty(docIds)){ return Action.SUCCESS; } - if(docIds.split(",").length <= 1){ - return Action.SUCCESS; - } + // 查询字段的目录 String docCategorys = Util.getDocCategorys(workflowId, mergeField); CreateDocForJSGJXT createDocForJSGJXT = new CreateDocForJSGJXT(); @@ -107,7 +111,29 @@ public class ConvertPdfAction implements Action { fileName = defaultFileName; } toolUtil.writeDebuggerLog("合并文件参数:fileName:" + fileName + " docCategory:" + docCategory + " docIds:" + docIds); - int fileId = createDocForJSGJXT.creatDoc(user, fileName, docCategory, docIds); + int fileId; + if(docIds.split(",").length <= 1){ +// 查询真实文件id + query = "select imagefileid from docimagefile where docid = ?"; + toolUtil.writeDebuggerLog(query + " ---> " + docIds); + rs.executeQuery(query,docIds); + rs.next(); + fileId = Util.getIntValue(rs.getString("imagefileid"),0); + FileProcessor fileProcessor = new FileProcessor(); + InputStream inputStreamById = ImageFileManager.getInputStreamById(fileId); + byte[] bytes = new byte[0]; + try { + bytes = IOUtils.toByteArray(inputStreamById); + } catch (IOException e) { + e.printStackTrace(); + toolUtil.writeErrorLog("复制文件时,文件转为base64出错,文件转换出错!" + e); + } + String base64 = Base64Utils.encode(bytes); + fileId = fileProcessor.Process("base64:" + base64, docCategorys, user, fileName); + }else{ + fileId = createDocForJSGJXT.creatDoc(user, fileName, docCategory, docIds); + } + if(fileId <= 0){ toolUtil.writeDebuggerLog("文件合并错误!(-2:用户为空,-1:文档获取异常)、错误id:" + fileId); // TODO 修改labelId