From 9025b9cf7ec8610003d445a31d93e35e7bd73c2e Mon Sep 17 00:00:00 2001
From: jinlin <jinlin>
Date: 星期三, 31 一月 2024 17:54:52 +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