Springboot + PDFbox 读取pdf文件每页前面插入

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

采用自助打印一体机,时时加盖鲜章,盖鲜章是垂直加盖,内容打印是在反面,需要在pdf 文件的每页前面添加空白页。

一、pdfbox文档

pdfbox 文档https://iowiki.com/pdfbox/pdfbox_index.html

二、具体实现

1.引入pdfbox 

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

2.插入空白页

 public static boolean addBlankPage(String srcPdf,String targetPdf){
        try {
            File file = new File(srcPdf);
            PDDocument pdDocument = PDDocument.load(file);
            PDDocument document = new PDDocument();
            for (int i=0;i<pdDocument.getNumberOfPages();i++) {
                PDPage page = pdDocument.getPage(i);
                document.addPage(new PDPage());
                document.addPage(page);
            }
            document.save(targetPdf);
            document.close();
            pdDocument.close();
            return true;
        }catch (Exception e){
            e.printStackTrace();
            return false;
        }
    }

总结

先读取到原始pdf文件的总页数,在将每页拆分成单页添加到新的文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现PDF预览可以使用以下步骤: 1. 后端使用SpringBoot框架,引入pdfbox库(可以使用Maven等工具进行管理),用于读取PDF文件内容。 2. 前端使用Vue框架,引入pdf.js库,用于在网页中展示PDF文件。 3. 后端提供一个接口,用于获取PDF文件内容,并返回给前端。 4. 前端通过Ajax请求后端接口,获取PDF文件内容,并使用pdf.js库在网页中展示PDF文件。 具体实现步骤如下: 后端实现: 1. 在pom.xml文件中添加pdfbox依赖: ```xml <dependency> <groupId>org.apache.pdfbox</groupId> <artifactId>pdfbox</artifactId> <version>2.0.17</version> </dependency> ``` 2. 定义一个Controller,提供一个接口用于获取PDF文件内容: ```java @RestController @RequestMapping("/api/pdf") public class PdfController { @GetMapping("/{filename}") public String getPdfContent(@PathVariable String filename) throws IOException { File file = new File("path/to/pdf/" + filename); PDDocument document = PDDocument.load(file); PDFTextStripper stripper = new PDFTextStripper(); String content = stripper.getText(document); document.close(); return content; } } ``` 3. 启动SpringBoot应用,访问`http://localhost:8080/api/pdf/test.pdf`即可获取test.pdf文件的内容。 前端实现: 1. 在Vue组件中引入pdf.js库: ```html <script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/2.3.200/pdf.min.js"></script> ``` 2. 在Vue组件中定义一个方法,用于获取PDF文件内容并展示: ```javascript methods: { loadPdf(filename) { axios.get(`/api/pdf/${filename}`) .then(response => { const data = response.data; const pdfDoc = pdfjsLib.getDocument({data: data}); pdfDoc.promise.then(pdf => { for (let i = 1; i <= pdf.numPages; i++) { pdf.getPage(i).then(page => { const canvas = document.createElement('canvas'); const scale = 1.5; const viewport = page.getViewport({scale: scale}); const context = canvas.getContext('2d'); canvas.height = viewport.height; canvas.width = viewport.width; const renderContext = { canvasContext: context, viewport: viewport }; page.render(renderContext).promise.then(() => { const img = canvas.toDataURL(); // 将img添加到页面中展示 }); }); } }); }) .catch(error => { console.error(error); }); } } ``` 3. 调用loadPdf方法,传入PDF文件名即可展示PDF文件。 以上就是使用SpringBoot和Vue实现PDF预览的步骤,可以根据实际需求进行调整和优化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值