zoukankan      html  css  js  c++  java
  • 使用icepdf将pdf文件转换成照片(以及隐藏的一个bug)

    首先引入依赖:

    <dependency>
    <groupId>org.apache.pdfbox</groupId>
    <artifactId>pdfbox</artifactId>
    <version>2.0.1</version>
    </dependency>

    首先先引入依赖,可能有的地方在引入jai_core这个包的时候,不能 引入,所以,需要将这个包排除.

    下面是经过测试的代码:

    public class PdfToImg {
        public static void main(String[] args) {
            String filePath = "E:\data\pdf\1.pdf";
            List<String> imageList = pdfToImagePath(filePath);
            Iterator<String> iterator = imageList.iterator();
            while (iterator.hasNext()) {
    
                System.out.println(iterator.next());
            }
            System.out.println(imageList);
        }
    
        public static List<String> pdfToImagePath(String filePath) {
            List<String> list = new ArrayList<>();
            String fileDirectory = filePath.substring(0, filePath.lastIndexOf("."));//获取去除后缀的文件路径
    
            String imagePath;
            File file = new File(filePath);
            try {
                File f = new File(fileDirectory);
                if (!f.exists()) {
                    f.mkdir();
                }
                PDDocument doc = PDDocument.load(file);
                PDFRenderer renderer = new PDFRenderer(doc);
                int pageCount = doc.getNumberOfPages();
                for (int i = 0; i < pageCount; i++) {
                    // 方式1,第二个参数是设置缩放比(即像素)
                    BufferedImage image = renderer.renderImageWithDPI(i, 296);
                    // 方式2,第二个参数是设置缩放比(即像素)
                    BufferedImage images = renderer.renderImage(i, 1.25f);  //第二个参数越大生成图片分辨率越高,转换时间也就越长
                    imagePath = fileDirectory + "/" + i + ".jpg";
                    ImageIO.write(images, "PNG", new File(imagePath));
                    list.add(imagePath);
                    return list;
                }
                doc.close();              //关闭文件,不然该pdf文件会一直被占用。
            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }
    }

    这个在本地运行是没有问题的.但是如果放在linux服务器上运行,就需要引入一个字体.这个字体为宋体,我用的为60M左右,所以包还是挺大的,如果不齐全,可以将自己电脑上的所有字体都放在服务器的user/share/fonts这个目录下,刷新缓存,然后重新启动服务,就可以正式将完整的照片进行转换,不然,转化出来的照片中的汉字会出现乱码的情况.

    上面说的两种方式进行设置可以进行预览,纯就是扯淡,只能通过具体的域名加上具体的路径才能真正的达到预览的效果.

  • 相关阅读:
    01 Vue的起步和插值表达式
    06 扩展的对象的功能
    05 解构赋值
    04 函数之扩展运算符、箭头函数
    03 函数之默认值、剩余参数
    02 模板字符串
    01 let和const命令
    28 Bootstrap排版
    27 Bootstrap的列偏移
    26 Bootstrap的栅格系统
  • 原文地址:https://www.cnblogs.com/qingmuchuanqi48/p/11677066.html
Copyright © 2011-2022 走看看