From 1772fc5e211f9e9e0ab4cdc6c29b436aac178c2a Mon Sep 17 00:00:00 2001
From: jinlin <jinlin>
Date: 星期五, 23 二月 2024 12:19:55 +0800
Subject: [PATCH] 修改
---
core/src/main/java/com/zt/life/export/service/WordFileService.java | 67 ++++++++++++++++++++++++++-------
1 files changed, 52 insertions(+), 15 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 642234f..1abcfb8 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,27 +8,40 @@
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;
+import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
+import java.awt.image.BufferedImage;
import java.io.*;
import java.lang.reflect.Field;
+import java.text.SimpleDateFormat;
import java.util.*;
@Service
public class WordFileService {
- public void exportWordFile(HttpServletRequest request, WordFile wordFile, HttpServletResponse response) throws UnsupportedEncodingException, FileNotFoundException {
+ @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> data = new HashMap<>();
+ Map<String, Object> wordData = new HashMap<>();
//HackLoopTableRenderPolicy hackLoopTableRenderPolicy = new HackLoopTableRenderPolicy();
Configure config = null;
ConfigureBuilder builder = Configure.newBuilder();
- this.formatWordData(wordFile, data, builder);
+ this.formatWordData(dataObj, wordData, builder);
config = builder.build();
- File fl = new File(wordFile.getModulePath());
+ File fl = new File(localPath + "/template/" + wordFile.getModulePath());
FileInputStream fs = new FileInputStream(fl);
XWPFTemplate template;
if (config != null) {
@@ -36,33 +49,57 @@
} else {
template = XWPFTemplate.compile(fs);
}
- template.render(data);
+ template.render(wordData);
DownloadService.download(request, response, template, wordFile.getWordName());
}
- public void formatWordData(Object obj, Map<String, Object> data, ConfigureBuilder builder) {
- Field[] fields = ReflectUtil.getFields(obj.getClass());
+ public void formatWordData(Object dataObj, Map<String, Object> wordData, ConfigureBuilder builder) {
+ Field[] fields = ReflectUtil.getFields(dataObj.getClass());
for (Field field : fields) {
field.setAccessible(true);
String fieldName = field.getName();
String typeName = field.getType().getName();
- Object staticFieldValue = ReflectUtil.getFieldValue(obj, field.getName()); // 灞炴�у搴旂殑鏁版嵁
+ Object staticFieldValue = ReflectUtil.getFieldValue(dataObj, field.getName()); // 灞炴�у搴旂殑鏁版嵁
if (typeName.contains("com.zt.life.modules")) {
- formatWordData(staticFieldValue, data, builder);
+ formatWordData(staticFieldValue, wordData, builder);
} else {
if (field.getType().getName().equals("java.util.List")) {
builder.bind(fieldName, new HackLoopTableRenderPolicy());
} else if (staticFieldValue != null) {
+ if (typeName.contains("java.util.Date") && fieldName.contains("Date")) {
+ SimpleDateFormat sdf = new SimpleDateFormat("yyyy骞碝M鏈坉d鏃�");
+ staticFieldValue = sdf.format(staticFieldValue);
+ }
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 = localPath + valStr.replace("鏂囦欢鍥剧墖:", "");
+ File file = new File(valStr);
+ if (file.exists() && !localPath.equals(valStr)) {
+ try (InputStream in = ossEncryptService.decrypt(file)) {
+ InputStream in2 = ossEncryptService.decrypt(file);
+ BufferedImage bufferedImage = ImageIO.read(in2);
+ int width = bufferedImage.getWidth();
+ int height = bufferedImage.getHeight();
+ if (width > 900 ) {
+ height = (height * 900) / width;
+ staticFieldValue = new PictureRenderData(900, height, ".png", in);
+ } else {
+ staticFieldValue = new PictureRenderData(width, height, ".png", in);
+ }
+ /*staticFieldValue = new PictureRenderData(80, 100, "d://" + valStr);*/
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ } else {
+ staticFieldValue = new PictureRenderData(100, 30, localPath + "template/noSign.png");
+ }
}
}
- if (data.get(fieldName) == null)
- data.put(fieldName, staticFieldValue);
+ if (wordData.get(fieldName) == null)
+ wordData.put(fieldName, staticFieldValue);
}
+ if (wordData.get(fieldName) == null)
+ wordData.put(fieldName, staticFieldValue);
}
}
}
--
Gitblit v1.9.1