pdf的base64转jpg/png的base64

//这个base64是pdf的base64
//想转jpg就将下面的png改为jpg
String base64 = result.getJSONObject(j).getString("base64");
                if (StringUtils.isEmpty(base64)){
                    System.out.println("空");
                }
                String jpg_base64 = null;
                Base64Decoder decoder = new Base64Decoder();
                try {
                    // Base64解码
                    byte[] pdf_bytes = decoder.decode(base64);
                    PDDocument doc = PDDocument.load(pdf_bytes);
                    int size = doc.getNumberOfPages();
                    /*图像合并使用的参数*/
                    //定义宽度
                    int width = 0;
                    // 保存一张图片中的RGB数据
                    int[] singleImgRGB;
                    // 定义高度,后面用于叠加
                    int shiftHeight = 0;
                    //保存每张图片的像素值
                    BufferedImage imageResult = null;
                    // 利用PdfBox生成图像
                    PDDocument pdDocument = doc;
                    PDFRenderer renderer = new PDFRenderer(pdDocument);
                    /*根据总页数, 按照50页生成一张长图片的逻辑, 进行拆分*/
                    // 每50页转成1张图片
                    int pageLength = size; //有多少转多少
                    // 总计循环的次数
                    int totalCount = pdDocument.getNumberOfPages() / pageLength + 1;
                    for (int m = 0; m < totalCount; m++) {
                        for (int i = 0; i < pageLength; i++) {
                            int pageIndex = i + (m * pageLength);
                            if (pageIndex == pdDocument.getNumberOfPages()) {
                                System.out.println("循环次数 m = " + m);
                                break;
                            }
                            // 96为图片的dpi,dpi越大,则图片越清晰,图片越大,转换耗费的时间也越多
                            BufferedImage image = renderer.renderImageWithDPI(pageIndex, 106, ImageType.RGB);
                            int imageHeight = image.getHeight();
                            int imageWidth = image.getWidth();
                            if (i == 0) {
                                //计算高度和偏移量
                                //使用第一张图片宽度;
                                width = imageWidth;
                                // 保存每页图片的像素值
                                // 加个判断:如果m次循环后所剩的图片总数小于pageLength,则图片高度按剩余的张数绘制,否则会出现长图片下面全是黑色的情况
                                if ((pdDocument.getNumberOfPages() - m * pageLength) < pageLength) {
                                    imageResult = new BufferedImage(width, imageHeight * (pdDocument.getNumberOfPages() - m * pageLength), BufferedImage.TYPE_INT_RGB);
                                } else {
                                    imageResult = new BufferedImage(width, imageHeight * pageLength, BufferedImage.TYPE_INT_RGB);
                                }
                            } else {
                                // 将高度不断累加
                                shiftHeight += imageHeight;
                            }
                            singleImgRGB = image.getRGB(0, 0, width, imageHeight, null, 0, width);
                            imageResult.setRGB(0, shiftHeight, width, imageHeight, singleImgRGB, 0, width);
                        }
                        // 这个很重要,下面会有说明
                        shiftHeight = 0;
                    }
                    pdDocument.close();
                    ByteArrayOutputStream baos = new ByteArrayOutputStream();//io流
                    ImageIO.write(imageResult, "png", baos);//写入流中 
                    byte[] jpg_Bytes = baos.toByteArray();//转换成字节 
                    BASE64Encoder encoder = new BASE64Encoder();
                    jpg_base64 = encoder.encodeBuffer(jpg_Bytes).trim();//转换成base64串
                    jpg_base64 = jpg_base64.replaceAll("\n", "").replaceAll("\r", "");//删除 \r\n
                    baos.close();
                    doc.close();
                    JSONObject resultJson = new JSONObject();
                    resultJson.put("base64",jpg_base64);
                    resultArr.add(resultJson);
                } catch (IOException e) {
                    e.printStackTrace();
                }

再贴上小程序展示base64代码

<image src="data:image/png;base64,{{base64}}"></image>
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
base64png换为base64jpg需要经过以下几个步骤: 1. 将base64png换为二进制数据; 2. 将二进制数据换为图像对象; 3. 将图像对象换为canvas对象; 4. 将canvas对象换为base64jpg。 具体的实现可以参考以下代码: ``` // 将base64png换为二进制数据 const base64ToBlob = function(base64) { const bytes = window.atob(base64.split(',')); const array = new Uint8Array(bytes.length); for (let i = 0; i < bytes.length; i++) { array[i] = bytes.charCodeAt(i); } return new Blob([array], {type: 'image/png'}); }; // 将二进制数据换为图像对象 const blobToImage = function(blob) { return new Promise((resolve, reject) => { const img = new Image(); img.onload = function() { resolve(img); }; img.onerror = function() { reject(); }; img.src = URL.createObjectURL(blob); }); }; // 将图像对象换为canvas对象 const imageToCanvas = function(image) { const canvas = document.createElement('canvas'); canvas.width = image.width; canvas.height = image.height; const context = canvas.getContext('2d'); context.drawImage(image, 0, 0, image.width, image.height); return canvas; }; // 将canvas对象换为base64jpg const canvasToBase64 = function(canvas) { return canvas.toDataURL('image/jpeg', 1); }; // 示例 const base64png = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAFElEQVR4AWPw2v7Wfe0f+gYGBgYGBoYBQABJzAU4AAAAASUVORK5CYII='; const blob = base64ToBlob(base64png); blobToImage(blob) .then(imageToCanvas) .then(canvasToBase64) .then(function(base64jpg) { console.log(base64jpg); }); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值