From e2cef6c358e57c2bc63e67a05c88c52585bb96db Mon Sep 17 00:00:00 2001
From: wente <329538422@qq.com>
Date: 星期五, 29 十二月 2023 11:22:29 +0800
Subject: [PATCH] 项目表

---
 core/src/main/java/com/zt/life/export/service/WordFileService.java |   49 +++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 43 insertions(+), 6 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 d1b3f77..331331f 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 {
+    @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<>();
         //HackLoopTableRenderPolicy hackLoopTableRenderPolicy = new HackLoopTableRenderPolicy();
         Configure config = null;
         ConfigureBuilder builder = Configure.newBuilder();
-        this.formatWordData(wordFile, wordData, 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) {
@@ -53,16 +66,40 @@
                 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-MM-dd");
+                        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 (wordData.get(fieldName) == null)
                     wordData.put(fieldName, staticFieldValue);
             }
+            if (wordData.get(fieldName) == null)
+                wordData.put(fieldName, staticFieldValue);
         }
     }
 }

--
Gitblit v1.9.1