1.构建依赖
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.13.3</version>
</dependency>
2.图片插入操作
1.导入
import com.itextpdf.text.*;
import com.itextpdf.text.pdf.PdfWriter;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
import java.io.*;
import java.util.ArrayList;
import java.util.List;
2.代码
//模拟服务器获得来的图片
List<String> list = new ArrayList<>();
list.add("http://127.0.0.1:8000/2023-09-25/ok/images/3016458-001.jpg");
list.add("http://127.0.0.1:8000/2023-09-25/ok/images/3016458-002.jpg");
Document document = new Document();
//准备生成的地址
PdfWriter.getInstance(document, new FileOutputStream("output1.pdf"));
//页面open操作,每次在循环中只执行一次
Boolean flag=true;
try {
for (String str : list) {
//每次循环都会用新的页面
document.newPage();
//插入图片
Image image = Image.getInstance(str);
//根据图片设置页面的大小
document.setPageSize(new Rectangle(
image.getWidth(),
image.getHeight()
));
if(flag){
document.open();
}
//表示图像的宽度相对于文档页面宽度的比例
float scale = ((document.getPageSize().getWidth()-document.leftMargin()-document.rightMargin() - 0) / image.getWidth()) * 100;
image.scalePercent(scale);
//图片自适应于页面
float imageWidth = image.getScaledWidth();
float imageHeight = image.getScaledHeight();
float x = (image.getWidth() - imageWidth) / 2;
float y = (image.getHeight() - imageHeight) / 2;
image.setAbsolutePosition(x, y);
//将图片插入页面
document.add(image);
flag=false;
}} catch (Exception e) {
e.printStackTrace();
} finally {
document.close();
}
3.将pdf拆分
1.导入
import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.PdfCopy;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import java.io.FileOutputStream;
2.方法
public static void splitPDFOneByOne(String path, String fileName, String outputPath) {
PdfReader reader = null;
try {
//读取页面
reader = new PdfReader(path + fileName);
//获取pdf页面
int numberOfPages = reader.getNumberOfPages();
for (int i = 1; i <= numberOfPages; i++) {
//创建一个新的Document对象,大小为PDF的第一页的尺寸
Document document = new Document(reader.getPageSize(1));
//准备生成的pdf名字
String savePath = outputPath + fileName.substring(0, fileName.lastIndexOf(".")) + "_" + i + ".pdf";
//克隆里边的内容
PdfCopy copy = new PdfCopy(document, new FileOutputStream(savePath));
//开启页面
document.open();
//新页面
document.newPage();
//从原始PDF文件中导入第i页
PdfImportedPage page = copy.getImportedPage(reader, i);
//将导入的页面添加到新的PDF文件中
copy.addPage(page);
document.close();
copy.close();
}} catch (Exception e) {
e.printStackTrace();
} finally {
reader.close();
}}
3.使用
splitPDFOneByOne("E:\\project\\demo\\", "output1.pdf", "E:\\project\\demo");