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

今天做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 {

/**

* 提取

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要修改 PDF 图片,可以使用 JavaPDFBox 库。PDFBox 是一个开源的 Java 库,用于处理 PDF 文件。下面是添加、提取、替换和删除 PDF 图片的示例代码: 1. 添加图片PDF ```java PDDocument document = PDDocument.load(new File("input.pdf")); PDPage page = document.getPage(0); // 添加图片 PDImageXObject image = PDImageXObject.createFromFile("image.jpg", document); PDPageContentStream contentStream = new PDPageContentStream(document, page); contentStream.drawImage(image, 100, 100); contentStream.close(); document.save("output.pdf"); document.close(); ``` 2. 提取 PDF 图片 ```java PDDocument document = PDDocument.load(new File("input.pdf")); List<PDPage> pages = document.getDocumentCatalog().getAllPages(); for (PDPage page : pages) { PDResources resources = page.getResources(); for (COSName name : resources.getXObjectNames()) { PDXObject object = resources.getXObject(name); if (object instanceof PDImageXObject) { PDImageXObject image = (PDImageXObject) object; // 保存图片 image.getImage().write2file("output.jpg"); } } } document.close(); ``` 3. 替换 PDF 图片 ```java PDDocument document = PDDocument.load(new File("input.pdf")); PDPage page = document.getPage(0); // 替换图片 PDImageXObject image = PDImageXObject.createFromFile("new_image.jpg", document); PDPageContentStream contentStream = new PDPageContentStream(document, page, PDPageContentStream.AppendMode.APPEND, false); contentStream.drawImage(image, 100, 100); contentStream.close(); document.save("output.pdf"); document.close(); ``` 4. 删除 PDF 图片 ```java PDDocument document = PDDocument.load(new File("input.pdf")); PDPage page = document.getPage(0); // 删除图片 PDResources resources = page.getResources(); resources.getCOSObject().removeItem(COSName.XOBJECT); document.save("output.pdf"); document.close(); ``` 以上是 Java 修改 PDF 图片的示例代码,供参考。但需要注意的是,PDFBox 库在处理大型 PDF 文件时可能会出现性能问题,因此建议在实际使用时进行测试。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值