From 38553de8fe4a824919563db827019909caa65f9c Mon Sep 17 00:00:00 2001
From: fei <791364011@qq.com>
Date: 星期三, 24 十二月 2025 10:34:59 +0800
Subject: [PATCH] 修改了对应代码

---
 archiveManager/src/main/java/com/ruoyi/service/impl/pdfGenerateService.java                 |    2 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/archiveAllExportController.java  |   18 ++--
 ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtilManySheetSecond.java         |    2 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/ArchiveRecordsController.java    |    2 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/DocumentMaterialsController.java |  182 +++++++++++++++++++++++++++++++++++++++++++--
 5 files changed, 185 insertions(+), 21 deletions(-)

diff --git a/archiveManager/src/main/java/com/ruoyi/service/impl/pdfGenerateService.java b/archiveManager/src/main/java/com/ruoyi/service/impl/pdfGenerateService.java
index 1a927a9..41e1fe2 100644
--- a/archiveManager/src/main/java/com/ruoyi/service/impl/pdfGenerateService.java
+++ b/archiveManager/src/main/java/com/ruoyi/service/impl/pdfGenerateService.java
@@ -47,7 +47,7 @@
     public byte[] createQrCodeN(String content, int width, int height) throws IOException {
         QrConfig config = new QrConfig(width, height);
 
-        config.setMargin(3);
+        config.setMargin(0);
         // 楂樼籂閿欑骇鍒�
         config.setErrorCorrection(ErrorCorrectionLevel.H);
         // 璁剧疆鍓嶆櫙鑹诧紝鏃簩缁寸爜棰滆壊锛堣嚜琛岄�夋嫨棰滆壊淇敼锛�
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/ArchiveRecordsController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/ArchiveRecordsController.java
index 88b41fc..41253a7 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/ArchiveRecordsController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/ArchiveRecordsController.java
@@ -73,7 +73,7 @@
     {
         List<AnalysisResult> list = archiveRecordsService.statisticAya();
         ExcelUtil<AnalysisResult> util = new ExcelUtil<AnalysisResult>(AnalysisResult.class);
-        util.exportExcel(response, list, "妗f鍒嗘瀽缁撴灉");
+        util.exportExcel(response, list, "妗堝嵎鐩綍");
     }
 
     /**
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/DocumentMaterialsController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/DocumentMaterialsController.java
index eb4bc64..9412e5e 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/DocumentMaterialsController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/DocumentMaterialsController.java
@@ -8,15 +8,17 @@
 import java.nio.file.Files;
 import java.nio.file.Path;
 import java.nio.file.Paths;
-import java.util.Collections;
-import java.util.HashMap;
+import java.time.LocalDate;
+import java.util.*;
 import java.util.List;
-import java.util.Objects;
 import java.util.concurrent.atomic.AtomicLong;
 import java.util.stream.Collectors;
+import java.util.zip.ZipEntry;
 import javax.imageio.ImageIO;
 import javax.servlet.http.HttpServletResponse;
 
+import com.aspose.words.License;
+import com.deepoove.poi.XWPFTemplate;
 import com.drew.imaging.ImageMetadataReader;
 import com.drew.metadata.Metadata;
 import com.drew.metadata.exif.ExifIFD0Directory;
@@ -25,18 +27,25 @@
 import com.ruoyi.common.utils.ServletUtils;
 import com.ruoyi.common.utils.file.FileUploadUtils;
 import com.ruoyi.common.utils.file.FileUtils;
+import com.ruoyi.common.utils.poi.ExcelExp;
+import com.ruoyi.common.utils.poi.ExcelUtilManySheet;
+import com.ruoyi.common.utils.poi.ExcelUtilManySheetSecond;
 import com.ruoyi.domain.ArchiveCategory;
 import com.ruoyi.domain.ArchiveRecords;
 import com.ruoyi.domain.DocumentMaterials;
-import com.ruoyi.domain.vo.DocumentMaterialFileSmallVo;
-import com.ruoyi.domain.vo.DocumentMaterialsVo;
-import com.ruoyi.domain.vo.DocumentMaterialsVoSmall;
+import com.ruoyi.domain.vo.*;
 import com.ruoyi.framework.config.ServerConfig;
 import com.ruoyi.framework.web.domain.server.Sys;
+import com.ruoyi.service.IArchiveRecordsService;
 import com.ruoyi.service.IDocumentMaterialsService;
+import com.ruoyi.service.impl.BarcodeService;
+import com.ruoyi.service.impl.pdfGenerateService;
+import com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
 import com.sun.xml.internal.ws.api.addressing.WSEndpointReference;
 import org.apache.commons.imaging.ImageInfo;
 import org.apache.commons.imaging.Imaging;
+import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
+import org.springframework.core.io.support.ResourcePatternResolver;
 import org.springframework.mock.web.MockMultipartFile;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -64,12 +73,16 @@
 public class DocumentMaterialsController extends BaseController
 {
     @Autowired
+    private BarcodeService barcodeService;
+    @Autowired
     private ServerConfig serverConfig;
-
+    @Autowired
+    private pdfGenerateService pdfGenerateService;
     @Autowired
     private IDocumentMaterialsService documentMaterialsService;
 
-
+    @Autowired
+    private IArchiveRecordsService iArchiveRecordsService;
     /**
      * 鍒ゆ柇PageNumber鏄惁杩炵画
      */
@@ -416,6 +429,157 @@
         ExcelUtil<DocumentMaterialFileSmallVo> util = new ExcelUtil<>(DocumentMaterialFileSmallVo.class);
         util.exportExcel(response,list,"妗f璇︾粏淇℃伅瀵煎叆妯℃澘");
     }
+    public  boolean getLicense() {
+        boolean result = false;
+        try {
+            InputStream is = null;
 
-    //瀵煎嚭material
+            ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
+            org.springframework.core.io.Resource[] resources = resolver.getResources("classpath:words.xml");
+            is = resources[0].getInputStream();
+            // 锟斤拷目锟斤拷lincense.xml锟斤拷路锟斤拷
+            License aposeLic = new License();
+            aposeLic.setLicense(is);
+            result = true;
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return result;
+    }
+    //瀵煎嚭澶囪�冭〃
+    @PostMapping("/exportBack/{id}/{recordId}")
+    public void exportBackInfo(HttpServletResponse response, @PathVariable Long id, @PathVariable String recordId)
+    {
+        //09-澶囪�冭〃.pdf
+        String pdf09Path = "09-澶囪�冭〃.pdf";
+        //  pdfGenerateService.generateFileStyleInfo(pdf09Path, aIV.getRecordId(), id);
+        //鎷垮埌鐩稿叧鏁版嵁
+        List<DocumentMaterialFileStyle> dmfs = documentMaterialsService.findFileStyleInfo(Math.toIntExact(id));
+
+        LocalDate currentDate = LocalDate.now();
+
+
+        String cdt = currentDate.getYear()+"骞�"+currentDate.getMonthValue()+"鏈�"+currentDate.getDayOfMonth()+"鏃�";
+
+        HashMap<String, Object> hs = new HashMap<String, Object>();
+        int allPages = 0;
+        int texPages = 0;
+        int picPages = 0;
+        int patPages = 0;
+        if(!dmfs.isEmpty())
+        {
+            for(DocumentMaterialFileStyle documentMaterialFileStyle:dmfs)
+            {
+                if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鏂囧瓧鏉愭枡"))
+                    texPages = documentMaterialFileStyle.getCnt();
+                if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鍥炬牱鏉愭枡"))
+                    patPages = documentMaterialFileStyle.getCnt();
+                if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鐓х墖鏉愭枡"))
+                    picPages = documentMaterialFileStyle.getCnt();
+            }
+        }
+        allPages = texPages + picPages + patPages;
+        hs.put("pages", allPages);
+        hs.put("patPages", patPages);
+        hs.put("picPages", picPages);
+        hs.put("texPages", texPages);
+        hs.put("volumeNumber", recordId);
+        hs.put("time", cdt);
+
+        if (!getLicense()) {
+            System.out.println("娌℃湁鐩稿叧璇佷功锛�");
+        }
+
+
+        try {
+
+            // 鑾峰彇 Word 妯℃澘鎵�鍦ㄨ矾寰�
+            String filepath = "09-澶囪�冭〃.docx";
+            // 閫氳繃 XWPFTemplate 缂栬瘧鏂囦欢骞舵覆鏌撴暟鎹埌妯℃澘涓�
+            XWPFTemplate template = XWPFTemplate.compile(filepath).render(hs
+            );
+
+            String renderedDocPath = "rendered_output.docx";
+            File renderedFile = new File(renderedDocPath);
+            try {
+                // 灏嗗畬鎴愭暟鎹覆鏌撶殑鏂囨。鍐欏嚭
+                template.writeAndClose(new FileOutputStream(renderedFile));
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
+
+            com.aspose.words.Document doc = new com.aspose.words.Document("rendered_output.docx");
+            // 鍒涘缓涓存椂瀛楄妭杈撳嚭娴�
+            ByteArrayOutputStream baobk = new ByteArrayOutputStream();
+            // 灏哤ord鏂囨。杞崲涓篜DF瀛楄妭鏁扮粍
+            doc.save(response.getOutputStream(), com.aspose.words.SaveFormat.PDF);//全锟斤拷支锟斤拷DOC, DOCX, OOXML, RTF HTML, OpenDocument, PDF, EPUB, XPS, SWF 锟洁互转锟斤拷
+
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+
+    }
+
+
+    //瀵煎嚭鍗峰唴鐩綍
+    @PostMapping("/exportJuan/{id}")
+
+    public void exportJuanInfo(HttpServletResponse response, @PathVariable Long id) throws IOException {
+        List<DocumentMaterialsVo> dsvs = documentMaterialsService.findArchMInfo(id.toString());
+
+        //鎷垮埌鍗峰唴鐩綍鐨別xcel
+        List<DocumentMaterialsVoSmall> list2 = dsvs.stream().map(res1 -> new DocumentMaterialsVoSmall(res1.getNum(), res1.getDocumentNumber(),res1.getCreator(),
+                res1.getTitle(), res1.getDate(), res1.getPageNumber(), res1.getRemarks())).collect(Collectors.toList());
+        if(!dsvs.isEmpty()) {
+            String recordId = dsvs.get(0).getRecordId();
+            byte[] imgr = barcodeService.generateBarcodeImage(recordId);
+            ExcelExp e1 = new ExcelExp("鍗峰唴鐩綍鏁版嵁", dsvs, DocumentMaterialsVo.class);
+            ExcelExp e2 = new ExcelExp("鍗峰唴鏁版嵁", list2, recordId, imgr, DocumentMaterialsVoSmall.class);
+            List<ExcelExp> mysheet = new ArrayList<ExcelExp>();
+            mysheet.add(e1);
+            mysheet.add(e2);
+            ExcelUtilManySheet<List<ExcelExp>> util2 = new ExcelUtilManySheet<List<ExcelExp>>(mysheet);
+          //  ZipEntry entr = new ZipEntry(fna + adir + "/" + "鍗峰唴鐩綍" + ".xls");
+            // ExcelUtil<DocumentMaterialsVo> util1 = new ExcelUtil<DocumentMaterialsVo>(DocumentMaterialsVo.class);
+         //   System.out.println(dsvs);
+         //  zos.putNextEntry(entr);
+            ByteOutputStream bos8 = new ByteOutputStream();
+
+            util2.exportExcelManySheet(bos8, mysheet);
+
+            bos8.writeTo( response.getOutputStream());
+
+
+        }
+    }
+
+    //瀵煎嚭妗堝嵎灏侀潰
+    @PostMapping("/exportPageInfo/{id}/{recordId}")
+    public void exportPageInfo(HttpServletResponse response, @PathVariable Long id, @PathVariable String recordId) throws IOException {
+
+        ArchiveInfoVo aIV = iArchiveRecordsService.selectByRecordId(id);
+
+        List<ArchiveInfoVo> arsi = new ArrayList<>();
+        arsi.add(aIV);
+
+        String recordId1 = recordId;
+        byte[] imgr1 = barcodeService.generateBarcodeImage(recordId1);
+        byte[] sedcode = pdfGenerateService.createQrCodeN(recordId1, 200, 200);
+        ExcelExp e3 = new ExcelExp("妗堝嵎灏侀潰鏁版嵁",arsi, ArchiveInfoVo.class);
+        ExcelExp e4 = new ExcelExp("妗堝嵎灏侀潰",  arsi, recordId1, imgr1,sedcode, ArchiveInfoVo.class);
+        List<ExcelExp> mysheet1 = new ArrayList<ExcelExp>();
+        mysheet1.add(e3);
+        mysheet1.add(e4);
+        ByteOutputStream bos2 = new ByteOutputStream();
+        ExcelUtilManySheetSecond<List<ExcelExp>> util3 = new ExcelUtilManySheetSecond<List<ExcelExp>>(mysheet1);
+
+        util3.exportExcelManySheet(bos2, mysheet1);
+
+        //  System.out.println(bos2);
+        bos2.writeTo(response.getOutputStream());
+
+    }
+
+
 }
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/archiveAllExportController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/archiveAllExportController.java
index ecf6382..59a8c6f 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/archiveAllExportController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/archive/archiveAllExportController.java
@@ -330,7 +330,7 @@
 
         String recordId = aIV.getRecordId();
         byte[] imgr = barcodeService.generateBarcodeImage(recordId);
-        byte[] sedcode = pdfGenerateService.createQrCodeN(recordId, 30, 30);
+        byte[] sedcode = pdfGenerateService.createQrCodeN(recordId, 100, 100);
         ExcelExp e1 = new ExcelExp("妗堝嵎灏侀潰鏁版嵁",arsi, ArchiveInfoVo.class);
         ExcelExp e2 = new ExcelExp("妗堝嵎灏侀潰",  arsi, recordId, imgr,sedcode, ArchiveInfoVo.class);
         List<ExcelExp> mysheet = new ArrayList<ExcelExp>();
@@ -561,11 +561,11 @@
                 {
                     for(DocumentMaterialFileStyle documentMaterialFileStyle:dmfs)
                     {
-                        if(documentMaterialFileStyle.getFileStyle().equals("鏂囧瓧鏉愭枡"))
+                        if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鏂囧瓧鏉愭枡"))
                             texPages = documentMaterialFileStyle.getCnt();
-                        if(documentMaterialFileStyle.getFileStyle().equals("鍥炬牱鏉愭枡"))
+                        if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鍥炬牱鏉愭枡"))
                             patPages = documentMaterialFileStyle.getCnt();
-                        if(documentMaterialFileStyle.getFileStyle().equals("鐓х墖鏉愭枡"))
+                        if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鐓х墖鏉愭枡"))
                             picPages = documentMaterialFileStyle.getCnt();
                     }
                 }
@@ -631,7 +631,7 @@
 
                 String recordId1 = aIV.getRecordId();
                 byte[] imgr1 = barcodeService.generateBarcodeImage(recordId1);
-                byte[] sedcode = pdfGenerateService.createQrCodeN(recordId1, 30, 30);
+                byte[] sedcode = pdfGenerateService.createQrCodeN(recordId1, 200, 200);
                 ExcelExp e3 = new ExcelExp("妗堝嵎灏侀潰鏁版嵁",arsi, ArchiveInfoVo.class);
                 ExcelExp e4 = new ExcelExp("妗堝嵎灏侀潰",  arsi, recordId1, imgr1,sedcode, ArchiveInfoVo.class);
                 List<ExcelExp> mysheet1 = new ArrayList<ExcelExp>();
@@ -1089,11 +1089,11 @@
             {
                 for(DocumentMaterialFileStyle documentMaterialFileStyle:dmfs)
                 {
-                    if(documentMaterialFileStyle.getFileStyle().equals("鏂囧瓧鏉愭枡"))
+                    if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鏂囧瓧鏉愭枡"))
                         texPages = documentMaterialFileStyle.getCnt();
-                    if(documentMaterialFileStyle.getFileStyle().equals("鍥炬牱鏉愭枡"))
+                    if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鍥炬牱鏉愭枡"))
                         patPages = documentMaterialFileStyle.getCnt();
-                    if(documentMaterialFileStyle.getFileStyle().equals("鐓х墖鏉愭枡"))
+                    if(documentMaterialFileStyle.getFileStyle()!=null&&documentMaterialFileStyle.getFileStyle().equals("鐓х墖鏉愭枡"))
                         picPages = documentMaterialFileStyle.getCnt();
                 }
             }
@@ -1179,7 +1179,7 @@
 
             String recordId1 = aIV.getRecordId();
             byte[] imgr1 = barcodeService.generateBarcodeImage(recordId1);
-            byte[] sedcode = pdfGenerateService.createQrCodeN(recordId1, 30, 30);
+            byte[] sedcode = pdfGenerateService.createQrCodeN(recordId1, 200, 200);
             ExcelExp e3 = new ExcelExp("妗堝嵎灏侀潰鏁版嵁",arsi, ArchiveInfoVo.class);
             ExcelExp e4 = new ExcelExp("妗堝嵎灏侀潰",  arsi, recordId1, imgr1,sedcode, ArchiveInfoVo.class);
             List<ExcelExp> mysheet1 = new ArrayList<ExcelExp>();
diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtilManySheetSecond.java b/ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtilManySheetSecond.java
index 65859d0..287e7b0 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtilManySheetSecond.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtilManySheetSecond.java
@@ -323,7 +323,7 @@
                         // 鍒涘缓鍥剧墖閿氱偣锛岃缃湪绗�2琛岀2鍒�
                         // 浜岀淮鐮佹樉绀哄湪鍙充笂瑙掍笖涓嶅~婊℃暣涓牸瀛�
                         // 缂╁皬鍥剧墖鑼冨洿锛氬彧鍗犵敤閮ㄥ垎鍗曞厓鏍肩┖闂�
-                        ClientAnchor anchor = new HSSFClientAnchor(600, 20, 1000, 200, (short) 1, 2, (short) 1, 2);
+                        ClientAnchor anchor = new HSSFClientAnchor(700, 20, 1000, 220, (short) 1, 2, (short) 1, 2);
                         // 璁剧疆鍥剧墖浣嶇疆鍜屽ぇ灏�
                         anchor.setAnchorType(ClientAnchor.AnchorType.MOVE_DONT_RESIZE);
                         

--
Gitblit v1.9.1