当前位置:   article > 正文

Java使用pdfbox将pdf转图片_org.apache.pdfbox.loader

org.apache.pdfbox.loader

前言

目前比较主流的两种转pdf的方式,就是pdfbox和icepdf,两种我都尝试了下,icepdf解析出来有时候会出现中文显示不出来,网上的解决方式又特别麻烦,不是安装字体,就是重写底层类,所以我选择了pdfbox

添加依赖

  1. <dependency>
  2. <groupId>org.apache.pdfbox</groupId>
  3. <artifactId>pdfbox</artifactId>
  4. <version>3.0.0</version>
  5. </dependency>

代码

  1. import org.apache.pdfbox.Loader;
  2. import org.apache.pdfbox.pdmodel.PDDocument;
  3. import org.apache.pdfbox.rendering.PDFRenderer;
  4. import javax.imageio.ImageIO;
  5. import java.awt.image.BufferedImage;
  6. import java.io.File;
  7. import java.nio.file.Files;
  8. import java.nio.file.Paths;
  9. public class Main {
  10. public static void main(String[] args) throws Exception {
  11. // 加载pdf文件
  12. PDDocument doc = Loader.loadPDF(new File("data.pdf"));
  13. // 2.x版本的pdfbox写法
  14. // PDDocument doc = PDDocument.load(new File("data.pdf"));
  15. PDFRenderer renderer = new PDFRenderer(doc);
  16. // 遍历每页pdf
  17. for (int i = 0; i < doc.getNumberOfPages(); i++) {
  18. // dpi调到300左右即可,太小会模糊,太大会使图片变得很大
  19. BufferedImage image = renderer.renderImageWithDPI(i, 300);
  20. ImageIO.write(image, "jpg", Files.newOutputStream(Paths.get("data_" + i + ".jpg")));
  21. }
  22. }
  23. }

在arm架构的linux上转换可能会出现模糊情况

在windows上好好的,x86_64的linux上也好好的,就是arm架构的linux上会出现

网上的博客基本上不是安装字体,就是重写底层类,但你永远不会想到是jdk的问题,这个一般是低版本的jdk8导致的

解决办法:将jdk8升级到8u311或以上,或者使用高版本的jdk即可

转换效果如下:

 附上高版本的jdk8下载地址:https://www.oracle.com/java/technologies/downloads/#java8 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/451297?site
推荐阅读
相关标签
  

闽ICP备14008679号