From c8d8a511f45c96ed3a5123a88e48de2ffdbf632a Mon Sep 17 00:00:00 2001
From: jinlin <jinlin>
Date: 星期日, 03 十二月 2023 20:00:47 +0800
Subject: [PATCH] 6
---
core/src/main/java/com/zt/life/export/service/WordFileService.java | 29 +++++++++++++++++++++--------
1 files changed, 21 insertions(+), 8 deletions(-)
diff --git a/core/src/main/java/com/zt/life/export/service/WordFileService.java b/core/src/main/java/com/zt/life/export/service/WordFileService.java
index 2329e9e..0576d03 100644
--- a/core/src/main/java/com/zt/life/export/service/WordFileService.java
+++ b/core/src/main/java/com/zt/life/export/service/WordFileService.java
@@ -8,6 +8,8 @@
import com.deepoove.poi.policy.HackLoopTableRenderPolicy;
import com.zt.life.export.dto.WordFile;
+import com.zt.life.oss.OssEncryptService;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
@@ -23,6 +25,10 @@
@Value("${zt.oss.local-path}")
private String localPath;
+ @Autowired
+ private OssEncryptService ossEncryptService;
+
+
public void exportWordFile(HttpServletRequest request, Object dataObj, WordFile wordFile, HttpServletResponse response) throws UnsupportedEncodingException, FileNotFoundException {
// 鏁版嵁map闆嗗悎
Map<String, Object> wordData = new HashMap<>();
@@ -32,7 +38,7 @@
this.formatWordData(dataObj, wordData, builder);
config = builder.build();
- File fl = new File(localPath+"/template/"+wordFile.getModulePath());
+ File fl = new File(localPath + "/template/" + wordFile.getModulePath());
FileInputStream fs = new FileInputStream(fl);
XWPFTemplate template;
if (config != null) {
@@ -55,17 +61,24 @@
formatWordData(staticFieldValue, wordData, builder);
} else {
if (field.getType().getName().equals("java.util.List")) {
- builder.bind(fieldName, new HackLoopTableRenderPolicy());
+ builder.bind(fieldName, new HackLoopTableRenderPolicy());
} else if (staticFieldValue != null) {
String valStr = staticFieldValue.toString();
- if (valStr.contains("绛惧悕鍥剧墖:")) {
- valStr = valStr.replace("绛惧悕鍥剧墖:", "");
- staticFieldValue = new PictureRenderData(80, 100, "d://" + valStr);
- /*put("localbyte", new PictureRenderData(80, 100, ".png", new FileInputStream("./logo.png")));*/
+ if (valStr.contains("鏂囦欢鍥剧墖:")) {
+ valStr = valStr.replace("鏂囦欢鍥剧墖:", "");
+ File file = new File(valStr);
+ if (file.exists()) {
+ try (InputStream in = ossEncryptService.decrypt(file)) {
+ staticFieldValue = new PictureRenderData(500, 500, ".png", in);
+ /*staticFieldValue = new PictureRenderData(80, 100, "d://" + valStr);*/
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
+ if (wordData.get(fieldName) == null)
+ wordData.put(fieldName, staticFieldValue);
}
}
- if (wordData.get(fieldName) == null)
- wordData.put(fieldName, staticFieldValue);
}
}
}
--
Gitblit v1.9.1