java pdfbox 提取pdf 标题_Java 使用PDFBox提取PDF文件中的图片

本文介绍了如何使用Apache PDFBox 1.8.13版本从PDF文件中提取并保存图片。在操作过程中,作者遇到了版本兼容性问题,指出高版本PDFBox可能移除了某些方法。提供的代码示例展示了提取和保存图片的完整流程。
摘要由CSDN通过智能技术生成

今天做PDF文件解析,遇到一个需求:提取文件中的图片并保存。使用的是流行的apache开源jar包pdfbox, 但还是遇到坑了,比如pdfbox版本太高或太低都不能用!!这个包竟然没有很好地做好兼容问题,有些方法在高版本说舍弃就舍弃了。暂时没有时间去研究版本间的区别。以下给我这个问题的解决方案。

pdfbox版本:1.8.13

maven传送门:

org.apache.pdfbox

pdfbox

1.8.13

代码:

package com.tbd.util;

import java.io.File;

import java.io.IOException;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import org.apache.pdfbox.pdmodel.PDDocument;

import org.apache.pdfbox.pdmodel.PDPage;

import org.apache.pdfbox.pdmodel.PDResources;

import org.apache.pdfbox.pdmodel.graphics.xobject.PDXObjectImage;

/**

* 提取PDF中的图片

* pdfbox 版本 1.8.13

* @author Charlie Wu

* 2018/05/24

*/

public class PDF2Image {

/**

* 提取

* @param filePDF文件

* @param targetFolder 图片存放目录

* @return

*/

public static boolean extractImages(File file, String targetFolder) {

boolean result = true;

try{

PDDocument document = PDDocument.load(file);

List pages = document.getDocumentCatalog().getAllPages();

Iterator iter = pages.iterator();

int count = 0;

while( iter.hasNext()){

PDPage page = (PDPage)iter.next();

PDResources resources = page.getResources();

Map images = resources.getImages();

if(images != null)

{

Iterator imageIter = images.keySet().iterator();

while(imageIter.hasNext())

{

count++;

String key = (String)imageIter.next();

PDXObjectImage image = (PDXObjectImage)images.get( key );

String name = file.getName() + "_" + count;// 图片文件名

image.write2file(targetFolder + name);// 保存图片

}

}

}

} catch(IOException ex){

ex.printStackTrace();

return false;

}

return result;

}

public static void main(String[] args) {

File file = new File("F:/test.pdf");

String targerFolder = "F:/target/";

extractImages(file, targerFolder);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值