当文件从.docx传递到pdf时,我遇到了问题。
我使用docx4j 3.2.2,用于转换的代码:
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import org.docx4j.Docx4J;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;
public class PDFConverter {
public static void main(String[] args) {
createPDF();
}
private static void createPDF() {
try {
long start = System.currentTimeMillis();
InputStream is = new FileInputStream(new File("docxFile"));
WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.load(is);
OutputStream out = new FileOutputStream(new File("pdfFile"));
Docx4J.toPDF(wordMLPackage, out);
} catch (Throwable e) {
e.printStackTrace();
}
}
}转换是真实的,但是pdf失去了格式,这里原始docx和pdf转换。
这是因为需要一些配置吗?
打招呼。
发布于 2017-10-31 08:44:01
package com.xxx.ecm.converter
import com.xxx.ecm.api.object.model.BaseContent
import org.docx4j.Docx4J
import org.docx4j.openpackaging.packages.WordprocessingMLPackage
class Docx2PdfConverter extends Converter
{
InputStream convert(BaseContent content) {
try {
byte[] bytes = content.inputStream.bytes
InputStream is = new ByteArrayInputStream(bytes)
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(bytes.size())
WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.load(is)
Docx4J.toPDF(wordMLPackage, outputStream);
new ByteArrayInputStream(outputStream.toByteArray())
} catch (Exception e) {
throw e
}
}
}https://stackoverflow.com/questions/41402691
复制相似问题