docx4j включает код для создания PDF-файла из документа docx с использованием iText. Он также может использовать POI для преобразования документа в документ.
Было время, когда мы поддерживали оба метода одинаково (а также PDF через XHTML), но мы решили сосредоточиться на XSL-FO.
Если это вариант, вам будет гораздо лучше использовать docx4j для преобразования docx в PDF через XSL-FO и FOP.
Используйте это так:
wordMLPackage = WordprocessingMLPackage.load(new java.io.File(inputfilepath));
// Set up font mapper
Mapper fontMapper = new IdentityPlusMapper();
wordMLPackage.setFontMapper(fontMapper);
// Example of mapping missing font Algerian to installed font Comic Sans MS
PhysicalFont font
= PhysicalFonts.getPhysicalFonts().get("Comic Sans MS");
fontMapper.getFontMappings().put("Algerian", font);
org.docx4j.convert.out.pdf.PdfConversion c
= new org.docx4j.convert.out.pdf.viaXSLFO.Conversion(wordMLPackage);
// = new org.docx4j.convert.out.pdf.viaIText.Conversion(wordMLPackage);
OutputStream os = new java.io.FileOutputStream(inputfilepath + ".pdf");
c.output(os);
Обновление июль 2016
Начиная с docx4j 3.3.0, коммерческий рендерер PDF от Plutext является опцией docx4j по умолчанию для преобразования docx в PDF. Вы можете попробовать онлайн демо на converter-eval.plutext.com
Если вы хотите использовать существующий подход docx к XSL-FO к PDF (или другую цель, поддерживаемую Apache FOP), просто добавьте jar docx4j-export-FO в ваш путь к классам.
В любом случае, для преобразования docx в PDF вы можете использовать метод toPDF фасада Docx4J.
Старый docx в PDF через код iText можно найти на https://github.com/plutext/docx4j-export-FO/.../docx4j-extras/PdfViaIText/