diff --git a/poi-tl/src/main/java/com/deepoove/poi/data/AttachmentType.java b/poi-tl/src/main/java/com/deepoove/poi/data/AttachmentType.java index c606de8f..b7c2b272 100644 --- a/poi-tl/src/main/java/com/deepoove/poi/data/AttachmentType.java +++ b/poi-tl/src/main/java/com/deepoove/poi/data/AttachmentType.java @@ -27,23 +27,23 @@ public enum AttachmentType { new String[]{"504B0304", "DOCF11E0"}, "Word.Document.12", "application/vnd.openxmlformats-officedocument.wordprocessingml.document", - POIXMLDocument.PACK_OBJECT_REL_TYPE, + POIXMLDocument.PACK_OBJECT_REL_TYPE, new String[]{".docx", ".doc"}, ""), - XLSX( + XLSX( new String[]{"504B0304", "DOCF11E0"}, "Excel.Sheet.12", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", - POIXMLDocument.PACK_OBJECT_REL_TYPE, + POIXMLDocument.PACK_OBJECT_REL_TYPE, new String[]{".xlsx", ".xls"}, ""), - OLE(new String[0], - "Package", - "application/vnd.openxmlformats-officedocument.oleObject", - POIXMLDocument.OLE_OBJECT_REL_TYPE, - new String[]{".png"}, - "") - ; + PDF(new String[]{"25504446"}, + "Package", + "application/vnd.openxmlformats-officedocument.oleObject", + POIXMLDocument.OLE_OBJECT_REL_TYPE, + new String[]{".pdf"}, + ""), + ; private final String[] fileMagics; private final String programId; @@ -56,7 +56,7 @@ public enum AttachmentType { this.fileMagics = fileMagics; this.programId = programId; this.contentType = contentType; - this.relType = relType; + this.relType = relType; this.extensions = extensions; this.icon = icon; } @@ -69,11 +69,11 @@ public String contentType() { return contentType; } - public String relType() { - return relType; - } + public String relType() { + return relType; + } - public String[] extensions() { + public String[] extensions() { return extensions; } diff --git a/poi-tl/src/main/java/com/deepoove/poi/data/OleObjectRenderData.java b/poi-tl/src/main/java/com/deepoove/poi/data/OleObjectRenderData.java deleted file mode 100644 index ff258b3a..00000000 --- a/poi-tl/src/main/java/com/deepoove/poi/data/OleObjectRenderData.java +++ /dev/null @@ -1,35 +0,0 @@ -package com.deepoove.poi.data; - -import com.deepoove.poi.util.ByteUtils; -import org.apache.commons.io.output.UnsynchronizedByteArrayOutputStream; -import org.apache.poi.hpsf.ClassIDPredefined; -import org.apache.poi.poifs.filesystem.DirectoryNode; -import org.apache.poi.poifs.filesystem.Ole10Native; -import org.apache.poi.poifs.filesystem.POIFSFileSystem; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.ByteArrayOutputStream; -import java.io.IOException; - - -public class OleObjectRenderData extends AttachmentRenderData { - - private static final Logger logger = LoggerFactory.getLogger(ByteUtils.class); - - private final byte[] origin; - - private final String fileName; - - public OleObjectRenderData(byte[] origin, String fileName) { - this.origin = origin; - this.fileName = fileName; - this.setFileType(AttachmentType.OLE); - } - - @Override - public byte[] readAttachmentData() { - - return origin; - } -} diff --git a/poi-tl/src/main/java/com/deepoove/poi/policy/AttachmentRenderPolicy.java b/poi-tl/src/main/java/com/deepoove/poi/policy/AttachmentRenderPolicy.java index 7a08deb7..1d58e321 100644 --- a/poi-tl/src/main/java/com/deepoove/poi/policy/AttachmentRenderPolicy.java +++ b/poi-tl/src/main/java/com/deepoove/poi/policy/AttachmentRenderPolicy.java @@ -15,12 +15,20 @@ */ package com.deepoove.poi.policy; +import java.io.ByteArrayOutputStream; +import java.io.IOException; import java.io.StringReader; import java.util.UUID; import java.util.concurrent.ThreadLocalRandom; +import org.apache.commons.io.output.UnsynchronizedByteArrayOutputStream; +import org.apache.poi.hpsf.ClassIDPredefined; +import org.apache.poi.ooxml.POIXMLDocument; import org.apache.poi.ooxml.POIXMLTypeLoader; import org.apache.poi.ooxml.util.DocumentHelper; +import org.apache.poi.poifs.filesystem.DirectoryNode; +import org.apache.poi.poifs.filesystem.Ole10Native; +import org.apache.poi.poifs.filesystem.POIFSFileSystem; import org.apache.poi.util.Units; import org.apache.poi.xwpf.usermodel.XWPFRun; import org.apache.xmlbeans.XmlObject; @@ -98,6 +106,9 @@ public void doRender(RenderContext context) throws Excepti AttachmentRenderData data = context.getData(); AttachmentType fileType = data.getFileType(); byte[] attachment = data.readAttachmentData(); + if (fileType.relType() == POIXMLDocument.OLE_OBJECT_REL_TYPE) { + attachment = wrapByOLE(attachment,fileType,uuidRandom); + } PictureRenderData icon = data.getIcon(); if (null == icon) { @@ -139,4 +150,20 @@ public void doRender(RenderContext context) throws Excepti ctr.set(XmlObject.Factory.parse(document.getDocumentElement(), POIXMLTypeLoader.DEFAULT_XML_OPTIONS)); } + private byte[] wrapByOLE(byte[] data, AttachmentType fileType, String uuid) throws IOException { + String fileName = uuid+fileType.ext(); + Ole10Native ole10 = new Ole10Native(fileName, fileName, fileName, data); + try (UnsynchronizedByteArrayOutputStream bos = new UnsynchronizedByteArrayOutputStream(data.length+500)) { + ole10.writeOut(bos); + try (POIFSFileSystem poifs = new POIFSFileSystem()) { + DirectoryNode root = poifs.getRoot(); + root.createDocument(Ole10Native.OLE10_NATIVE, bos.toInputStream()); + root.setStorageClsid(ClassIDPredefined.OLE_V1_PACKAGE.getClassID()); + try (ByteArrayOutputStream os = new ByteArrayOutputStream()) { + poifs.writeFilesystem(os); + return os.toByteArray(); + } + } + } + } } \ No newline at end of file diff --git a/poi-tl/src/test/java/com/deepoove/poi/tl/policy/AttachmentRenderTest.java b/poi-tl/src/test/java/com/deepoove/poi/tl/policy/AttachmentRenderTest.java index f82af3df..40381b65 100644 --- a/poi-tl/src/test/java/com/deepoove/poi/tl/policy/AttachmentRenderTest.java +++ b/poi-tl/src/test/java/com/deepoove/poi/tl/policy/AttachmentRenderTest.java @@ -80,7 +80,8 @@ public void testAttachmentRender() throws Exception { .create()); put("xlsx", Attachments.ofLocal("src/test/resources/template/attachment.xlsx", AttachmentType.XLSX) .create()); - put("oleObject", new OleObjectRenderData(Files.readAllBytes(Paths.get("src/test/resources/logo.png")),"logo.png")); + put("oleObject", Attachments.ofLocal("src/test/resources/test.pdf", AttachmentType.PDF) + .create()); put("chart", Charts .ofMultiSeries("CustomTitle", new String[] { "中文", "English", "日本語", "português", "中文", "English", "日本語", diff --git a/poi-tl/src/test/resources/test.pdf b/poi-tl/src/test/resources/test.pdf new file mode 100644 index 00000000..588a1879 Binary files /dev/null and b/poi-tl/src/test/resources/test.pdf differ