nodejs 实现pdf与图片互转

PDF转图片

效果图
代码
javascript 复制代码
const path = require('path');  
const pdf = require('pdf-poppler');  
const fs = require('fs');  
  
// PDF文件路径  
const pdfFilePath = './path/test.pdf';  
  
// 转换选项  
const opts = {  
  format: 'png', // 输出图片格式,可以是 'jpeg', 'png', 'ppm', 'tiff', 'xps', 'xml', 'xps1', 'xps2' 等  
  out_dir: './path/output', // 输出目录  
  out_prefix: 'outputImg', // 输出文件的前缀  
  page: null // 要转换的页码,可以是具体的页码或者一个页码范围,例如 [1, 3, 5] 或者 '1-5'  
};  
  
// 转换PDF为图片  
pdf.convert(pdfFilePath, opts)  
  .then(res => {  
    console.log('Successfully converted:', res);  
    // res 是一个包含转换后图片文件路径的数组  
    // 例如:['./output/output-1.jpeg', './output/output-2.jpeg']  
  })  
  .catch(error => {  
    console.error('Error converting PDF to images:', error);  
  });

图片转PDF

效果图如下
代码:
javascript 复制代码
const PDFDocument = require('pdfkit');  
const fs = require('fs');  
const path = require('path');  
  
// 创建一个PDF文档  
const doc = new PDFDocument();  
  
// 设置文档元数据(可选)  
doc.info.title = 'My Image to PDF';  
  
// 将PDF文档流写入一个文件  
const outputStream = fs.createWriteStream(path.resolve('./path/output/output.pdf'));  
doc.pipe(outputStream);  
  
// 将图片添加到PDF文档中  
doc.image('./path/zgr.jpg', {  
  width: 500, // 设置图片宽度  
  height: 300, // 设置图片高度  
  fit: [500, 300] // 或者使用fit来适应指定尺寸  
});  
  
// 结束文档并关闭流  
doc.end();  
  
outputStream.on('finish', () => {  
  console.log('PDF生成完成');  
});  
  
outputStream.on('error', (err) => {  
  console.error('PDF生成出错:', err);  
});
相关推荐
Zz_waiting.10 分钟前
Javaweb - 14.6 - Vue3 数据交互 Axios
开发语言·前端·javascript·vue·axios
切糕师学AI22 分钟前
前后端分离架构中,Node.js的底层实现原理与线程池饥饿问题解析
前端·vue.js·node.js
妄小闲41 分钟前
网页设计模板 HTML源码网站模板下载
前端·html
icebreaker1 小时前
tailwindcss 究竟比 unocss 快多少?
前端·css·github
卢叁1 小时前
Flutter之自定义TabIndicator
前端·flutter
虎头金猫1 小时前
如何在Linux上使用Docker在本地部署开源PDF工具Stirling PDF:StirlingPDF+cpolar让专业操作像在线文档一样简单
linux·运维·ubuntu·docker·pdf·开源·centos
每天吃饭的羊1 小时前
state和ref
前端·javascript·react.js
GEO_YScsn1 小时前
Vite:Next-Gen Frontend Tooling 的高效之道——从原理到实践的性能革命
前端·javascript·css·tensorflow
GISer_Jing1 小时前
滴滴二面(准备二)
前端·javascript·vue·reactjs
ningmengjing_1 小时前
webpack打包方式
前端·爬虫·webpack·node.js·逆向