base64转pdf pdf转image

maven

<dependency>
	<groupId>org.apache.pdfbox</groupId>
	<artifactId>pdfbox</artifactId>
	<version>2.0.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.6</version>
</dependency>

测试类

package com.pdf;

import java.awt.image.BufferedImage;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;

import javax.imageio.ImageIO;

import org.apache.commons.io.FileUtils;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPageTree;
import org.apache.pdfbox.rendering.PDFRenderer;

import sun.misc.BASE64Decoder;

public class Base64ToPdf {
public static void main(String[] args) throws Exception {
String base64 = “”;
base64StringToPdf(base64,“d://123.pdf”);

	pdfToImg("d://123.pdf","d://123.png","png");
}

/**
 * 
 * @param base64Content
 * @param filePath
 * @return
 * @throws Exception
 */
public static boolean base64StringToPdf(String base64Content,String filePath) throws Exception{
    BASE64Decoder decoder = new BASE64Decoder();
    BufferedInputStream bis = null;
    FileOutputStream fos = null;
    BufferedOutputStream bos = null;

    try {
        byte[] bytes = decoder.decodeBuffer(base64Content);//base64编码内容转换为字节数组
        
        bis = new BufferedInputStream(new ByteArrayInputStream(bytes));
        
        File file = new File(filePath);
        file.getParentFile().mkdirs();
        
        fos = new FileOutputStream(file);
        bos = new BufferedOutputStream(fos);

        byte[] buffer = new byte[1024];
        int length = bis.read(buffer);
        while(length != -1){
            bos.write(buffer, 0, length);
            length = bis.read(buffer);
        }
        bos.flush();
        return true;
    } catch (Exception e) {
        e.printStackTrace();
        throw e;
    }finally{
        try {
        	bis.close();
        	fos.close();
        	bos.close();
        } catch (Exception e) {
        }
    }
}

/**
 * pdf转图片
 * @param pdfPath
 * @param imgPath
 * @param formatName
 */
public static void pdfToImg(String pdfPath,String imgPath,String formatName){
    InputStream stream = null;
    try {
        stream = new FileInputStream(new File(pdfPath));
        PDDocument doc = PDDocument.load(stream);
        PDFRenderer pdfRenderer = new PDFRenderer(doc);
        PDPageTree pages = doc.getPages();
        int pageCount = pages.getCount();
        for (int i = 0; i < pageCount; i++) {
            BufferedImage bim = pdfRenderer.renderImageWithDPI(i, 200);
            ByteArrayOutputStream os = new ByteArrayOutputStream();
            ImageIO.write(bim, formatName, os);
            byte[] datas = os.toByteArray();
            FileUtils.writeByteArrayToFile(new File(imgPath),datas);
        }

    }catch (Exception e){

    }

}

}

图片image)的Base64编码换成PDFBase64编码,通常涉及到两个步骤:首先需要将图片数据从Base64解码并换成二进制文件格式,然后将这个图像插入到PDF文档中,并再次把整个PDF内容Base64。 1. **解码图片**:使用库如`js-base64`(JavaScript)或`python Imaging Library (PIL)`(Python),将Base64字符串换成原始的字节流。 ```javascript const imgData = 'your_base64_string'; let buffer = Buffer.from(imgData, 'base64'); ``` ```python import base64 img_data = base64.b64decode('your_base64_string') ``` 2. **创建PDF**:使用库如`pdfkit`(JavaScript)、`reportlab`(Python)或`pypdf2`(Python),创建一个新的PDF文档,并添加图片。 3. **PDF内容Base64编码**:将生成的PDF换成字节流,再将其换为Base64字符串。 ```javascript const PDFDocument = require('pdfkit'); const doc = new PDFDocument(); doc.image(buffer, 0, 0); let pdfBytes = await doc.pipe().toBuffer(); let pdfBase64 = Buffer.from(pdfBytes).toString('base64'); ``` ```python from reportlab.pdfgen import canvas c = canvas.Canvas("output.pdf") c.drawImage(img_data, x=0, y=0) # 图片位置 pdf_bytes = io.BytesIO() c.save() pdf_base64 = base64.b64encode(pdf_bytes.getvalue()).decode() ``` 请注意,这只是一个基本流程,实际过程中可能会有更多细节和错误处理。而且,由于PDF生成和Base64编码的复杂性,这种方法并不适用于所有场景,例如网络传输限制等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值