当前位置: 首页 > news >正文

外部链接链轮的建设对于网站提龙岗公司做网站

外部链接链轮的建设对于网站提,龙岗公司做网站,源码编程器,广州市律师网站建设公司这篇文章#xff0c;主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件#xff0c;图片旋转、图片缩放。 目录 一、itext7合并PDF 1.1、引入依赖 1.2、合并PDF介绍 1.3、采用字节数组方式读取PDF文件 1.4、合并多个PDF文件 1.5、合并图片到PDF文件 1.6、旋转图… 这篇文章主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件图片旋转、图片缩放。 目录 一、itext7合并PDF 1.1、引入依赖 1.2、合并PDF介绍 1.3、采用字节数组方式读取PDF文件 1.4、合并多个PDF文件 1.5、合并图片到PDF文件 1.6、旋转图片 1.7、完整案例代码 1PDFUtil工具类 2测试类代码 3合并效果 一、itext7合并PDF 1.1、引入依赖 我这里使用的是itext-core7.1.16版本只需要引入一个itext-core依赖即可因为这个依赖里面已经给我们引入了itext所需要的依赖。 !-- 引入 itext7-core 依赖 -- dependencygroupIdcom.itextpdf/groupIdartifactIditext7-core/artifactIdversion7.1.16/versiontypepom/type /dependency 1.2、合并PDF介绍 最简单的合并方式那就是读取两个PDF文件然后将其合并成一个新的PDF文件保存到服务器上面之后在将这个新的PDF文件和下一个待合并的PDF文件进行合并以此类推最终可以得到一个完整的PDF文件但是这种方式缺点在于每一次合并之后都需要新生成一个PDF文件并且下一次合并之后还要再读取这个PDF文件这就会导致多次读取文件的过程效率不是很理想。 这篇文章我主要是将PDF作为字节数组读取到内存里面然后在内存中合并两个PDF的字节数据这样可以减少读取和生成PDF文件的次数执行效率方面也就会更加好一些了合并两个PDF字节数组的方法如下所示 /*** 基于内存中的字节数组进行PDF文档的合并* param firstPdf 第一个PDF文档* param secondPdf 第二个PDF文档*/ private static byte[] mergePdfBytes(byte[] firstPdf, byte[] secondPdf) throws IOException {if (firstPdf ! null secondPdf ! null) {// 创建字节数组基于内存进行合并ByteArrayOutputStream baos new ByteArrayOutputStream();PdfDocument destDoc new PdfDocument(new PdfWriter(baos));// 合并的pdf文件对象PdfDocument firstDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(firstPdf)));PdfDocument secondDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(secondPdf)));// 合并对象PdfMerger merger new PdfMerger(destDoc);merger.merge(firstDoc, 1, firstDoc.getNumberOfPages());merger.merge(secondDoc, 1, secondDoc.getNumberOfPages());// 关闭文档流merger.close();firstDoc.close();secondDoc.close();destDoc.close();return baos.toByteArray();}return null; } 1.3、采用字节数组方式读取PDF文件 合并PDF文件的时候有些PDF文件可能是网络上的也有些是本地磁盘上的所以这里需要做下判断如果是网络上的PDF文件则需要首先访问网络再将其保存到字节数组里面如果是本地磁盘文件则需要读取本地文件。 /*** 将pdf文档转换成字节数组* param pdf PDF文档路径* return 返回对应PDF文档的字节数组*/ private static byte[] getPdfBytes(String pdf) throws Exception {ByteArrayOutputStream out new ByteArrayOutputStream();InputStream is;if (pdf.startsWith(http://) || pdf.startsWith(https://)) {is new URL(pdf).openStream();} else {is new FileInputStream(pdf);}byte[] data new byte[2048];int len;while ((len is.read(data)) ! -1) {out.write(data, 0, len);}return out.toByteArray(); } 1.4、合并多个PDF文件 合并PDF时候直接传递需要合并的PDF文件路径就可以啦调用下面方法就可以完成合并。 /*** 将给定List集合中的pdf文档按照顺序依次合并生成最终的目标PDF文档* param pdfPathLists 待合并的PDF文档路径集合可以是本地PDF文档也可以是网络上的PDF文档* param destPath 目标合并生成的PDF文档路径*/ public static boolean mergeMultiplePdfs(ListString pdfPathLists, String destPath) {try {int size pdfPathLists.size();byte[] pdfData getPdfBytes(pdfPathLists.get(0));for (int i 1; i size; i) {pdfData mergePdfBytes(pdfData, getPdfBytes(pdfPathLists.get(i)));}if (pdfData ! null) {FileOutputStream fis new FileOutputStream(destPath);fis.write(pdfData);fis.close();}return true;} catch (Exception e) {logger.error(合并PDF异常:, e);}return false; } 1.5、合并图片到PDF文件 如何将图片也一起合并到PDF文件里面呢这里我是将图片直接添加到PDF文件的空白页面中实现的一张图片占据一个页面当然你也可以设置显示在相同页面超过之后页面高度之后图片会自动显示到下一个页面。 /*** 将给定集合中的图片合并到一个pdf文档里面* param imagePathList 图片路径集合* param destPath 合并之后的PDF文档*/ public static boolean mergeImagesToPdf(ListString imagePathList, String destPath) {try {PdfDocument pdfDocument new PdfDocument(new PdfWriter(destPath));Document document new Document(pdfDocument);if (imagePathList ! null imagePathList.size() 0) {int size imagePathList.size();for (int i 0; i size; i) {String imgPath imagePathList.get(i);ImageData imageData;if (imgPath.startsWith(http://) || imgPath.startsWith(https://)) {imageData ImageDataFactory.create(new URL(imgPath));} else {imageData ImageDataFactory.create(imgPath);}Image image new Image(imageData);/*设置旋转的弧度值默认是逆时针旋转的。弧度、角度换算公式1° PI / 180°1 rad 180° / PI*/image.setRotationAngle(- Math.PI / 2); // 顺时针旋转90°// 设置图片自动缩放即图片宽高自适应image.setAutoScale(true);document.add(image);if (i ! size - 1) {// 最后一页不需要新增空白页document.add(new AreaBreak(AreaBreakType.NEXT_PAGE));}}}pdfDocument.close();return true;} catch (Exception e) {logger.error(合并图片到PDF异常:, e);}return false; } 1.6、旋转图片 在某些需求下你可以想某个图片竖向摆放、某些图片横向摆放那么这个时候就可以调用itext7中【Image】图片对象的【setRotationAngle()】方法对其进行旋转需要注意的是setRotationAngle方法设置的旋转弧度而不是旋转角度并且它是逆时针旋转的。弧度和角度之间有一个转换公式如下所示 1.7、完整案例代码 1PDFUtil工具类 package com.gitcode.itext.util;import com.itextpdf.io.image.ImageData; import com.itextpdf.io.image.ImageDataFactory; import com.itextpdf.kernel.pdf.PdfDocument; import com.itextpdf.kernel.pdf.PdfReader; import com.itextpdf.kernel.pdf.PdfWriter; import com.itextpdf.kernel.utils.PdfMerger; import com.itextpdf.layout.Document; import com.itextpdf.layout.element.AreaBreak; import com.itextpdf.layout.element.Image; import com.itextpdf.layout.property.AreaBreakType; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.io.*; import java.net.URL; import java.util.List;/*** version 1.0.0* Date: 2023/10/04 10:07* Author ZhuYouBin* Description: PDF工具类【基于 itext7 组件实现】*/ public class PDFUtil {private static final Logger logger LoggerFactory.getLogger(PDFUtil.class);/*** 将给定List集合中的pdf文档按照顺序依次合并生成最终的目标PDF文档* param pdfPathLists 待合并的PDF文档路径集合可以是本地PDF文档也可以是网络上的PDF文档* param destPath 目标合并生成的PDF文档路径*/public static boolean mergeMultiplePdfs(ListString pdfPathLists, String destPath) {try {int size pdfPathLists.size();byte[] pdfData getPdfBytes(pdfPathLists.get(0));for (int i 1; i size; i) {pdfData mergePdfBytes(pdfData, getPdfBytes(pdfPathLists.get(i)));}if (pdfData ! null) {FileOutputStream fis new FileOutputStream(destPath);fis.write(pdfData);fis.close();}return true;} catch (Exception e) {logger.error(合并PDF异常:, e);}return false;}/*** 将给定集合中的图片合并到一个pdf文档里面* param imagePathList 图片路径集合* param destPath 合并之后的PDF文档*/public static boolean mergeImagesToPdf(ListString imagePathList, String destPath) {try {PdfDocument pdfDocument new PdfDocument(new PdfWriter(destPath));Document document new Document(pdfDocument);if (imagePathList ! null imagePathList.size() 0) {int size imagePathList.size();for (int i 0; i size; i) {String imgPath imagePathList.get(i);ImageData imageData;if (imgPath.startsWith(http://) || imgPath.startsWith(https://)) {imageData ImageDataFactory.create(new URL(imgPath));} else {imageData ImageDataFactory.create(imgPath);}Image image new Image(imageData);/*设置旋转的弧度值默认是逆时针旋转的。弧度、角度换算公式1° PI / 180°1 rad 180° / PI*/image.setRotationAngle(- Math.PI / 2); // 顺时针旋转90°// 设置图片自动缩放即图片宽高自适应image.setAutoScale(true);document.add(image);if (i ! size - 1) {// 最后一页不需要新增空白页document.add(new AreaBreak(AreaBreakType.NEXT_PAGE));}}}pdfDocument.close();return true;} catch (Exception e) {logger.error(合并图片到PDF异常:, e);}return false;}/*** 基于内存中的字节数组进行PDF文档的合并* param firstPdf 第一个PDF文档* param secondPdf 第二个PDF文档*/private static byte[] mergePdfBytes(byte[] firstPdf, byte[] secondPdf) throws IOException {if (firstPdf ! null secondPdf ! null) {// 创建字节数组基于内存进行合并ByteArrayOutputStream baos new ByteArrayOutputStream();PdfDocument destDoc new PdfDocument(new PdfWriter(baos));// 合并的pdf文件对象PdfDocument firstDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(firstPdf)));PdfDocument secondDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(secondPdf)));// 合并对象PdfMerger merger new PdfMerger(destDoc);merger.merge(firstDoc, 1, firstDoc.getNumberOfPages());merger.merge(secondDoc, 1, secondDoc.getNumberOfPages());// 关闭文档流merger.close();firstDoc.close();secondDoc.close();destDoc.close();return baos.toByteArray();}return null;}/*** 将pdf文档转换成字节数组* param pdf PDF文档路径* return 返回对应PDF文档的字节数组*/private static byte[] getPdfBytes(String pdf) throws Exception {ByteArrayOutputStream out new ByteArrayOutputStream();InputStream is;if (pdf.startsWith(http://) || pdf.startsWith(https://)) {is new URL(pdf).openStream();} else {is new FileInputStream(pdf);}byte[] data new byte[2048];int len;while ((len is.read(data)) ! -1) {out.write(data, 0, len);}return out.toByteArray();} }2测试类代码 package com.gitcode.itext;import com.gitcode.itext.util.PDFUtil;import java.io.FileNotFoundException; import java.util.ArrayList; import java.util.List;/*** version 1.0.0* Date: 2023/10/4 11:12* Author ZhuYouBin* Description:*/ public class ImageDemo {public static void main(String[] args) throws FileNotFoundException {// 图片合并之后生成的PDF路径String imagePath F:\\pdf-demo\\imagePath.pdf;ListString imageList new ArrayList();imageList.add(F:\\pdf-demo\\01.jpg);imageList.add(F:\\pdf-demo\\02.jpg);// 先合并图片PDFUtil.mergeImagesToPdf(imageList, imagePath);// 在合并PDFString destPath F:\\pdf-demo\\merge.pdf;ListString pdfPath new ArrayList();pdfPath.add(F:\\pdf-demo\\demo01.pdf);pdfPath.add(F:\\pdf-demo\\demo02.pdf);pdfPath.add(imagePath);PDFUtil.mergeMultiplePdfs(pdfPath, destPath);} }3合并效果 到此itext7合并PDF文件就介绍完啦。 综上这篇文章结束了主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件图片旋转、图片缩放。
http://www.zqtcl.cn/news/894557/

相关文章:

  • 国外域名注册商网站邮箱登陆登录入口
  • 男女做那个的网站是什么深圳市8号公告
  • 做网站收款支付宝接口廊坊市网站建设公司
  • 文档下载网站 建设做cpa用什么网站
  • 网站制作合同注意事项百度网页版电脑版
  • 怎样做模板网站手机营销型网站制作
  • 如何采集网站内容如何做网站导航栏的搜索引擎优化
  • 网站关键词排名外包织梦大气婚纱影楼网站源码
  • 网站建设执行力冠县哪里有做网站的
  • 免费网站推广咱们做网络营销推广的应用场景
  • 深圳正规网站制作哪家公司好做网站代理属于开设赌场罪吗
  • 江西宜春市建设局网站wordpress博客下载器
  • 汕头站扩建效果图微信怎么引流营销呢
  • 小学学校网站建设计划wordpress博客示例
  • 德邦公司网站建设特点万网是什么
  • 天津武清网站开发广东省建筑网站
  • 青岛做外贸网站哪家好佛山网站建设哪家好
  • 网站关键词设置技巧wordpress 获得参数
  • 程序网站开发搜索引擎有哪些技巧
  • 网站模板上传教程响应式网站建设免费
  • 网站建设与设计ppt模板wordpress调用大全
  • wordpress信息修改佛山网站优化如何
  • 最权威的排行榜网站招网站开发人员
  • 北京通州住房和城乡建设部网站网站获取访客手机号源码
  • 网站开发与建设网站程序基础
  • 网站建设属于什么税php网站建设全程实例
  • 做网站语言排名2018淄博市沂源县建设局网站
  • 腾冲网站建设哪个电商平台最好
  • 重点实验室网站建设宁波seo优化服务
  • 怎么用手机做刷会员网站网页设计指什么