pdf-to-img
Version:
ššø Converts PDFs to images in nodejs
121 lines (87 loc) ⢠3.39 kB
Markdown
[](https://github.com/k-yle/pdf-to-img/actions)
[](https://coveralls.io/github/k-yle/pdf-to-img?branch=main)
[](https://badge.fury.io/js/pdf-to-img)
[](https://www.npmjs.com/package/pdf-to-img)

ššø Converts PDFs to images in nodejs.
Useful for unit tests of PDFs
Supports nodejs v18+, and comes with a CLI.
```sh
npm install -S pdf-to-img
```
> [!IMPORTANT]
> You should use v4 by default. v4 requires nodejs v18 or later, and ESM modules.
>
> If you can't upgrade to v4 yet, you can still use v3. If you use v3, you can safely ignore `npm audit`'s [warning about pdfjs-dist](https://github.com/advisories/GHSA-wgrm-67xf-hhpq), since this library [disables `eval` by default](https://github.com/k-yle/pdf-to-img/commit/bdac3a1dcc2004c3f1fe7380bbb860086ec2746f).
NodeJS (using ESM Modules):
```js
import { promises as fs } from "node:fs";
import { pdf } from "pdf-to-img";
async function main() {
let counter = 1;
const document = await pdf("example.pdf", { scale: 3 });
for await (const image of document) {
await fs.writeFile(`page${counter}.png`, image);
counter++;
}
// you can also read a specific page number:
const page12buffer = await document.getPage(12)
}
main();
```
If your app does not support ESM modules, you can use v3 (see the warning above), or just change the import:
```diff
+ const { promises: fs } = require("node:fs");
- import { promises as fs } from "node:fs";
- import { pdf } from "pdf-to-img";
async function main() {
+ const { pdf } = await import("pdf-to-img");
let counter = 1;
const document = await pdf("example.pdf", { scale: 3 });
for await (const image of document) {
await fs.writeFile(`page${counter}.png`, image);
counter++;
}
}
main();
```
Using jest (or vitest) with [jest-image-snapshot](https://npm.im/jest-image-snapshot):
```js
import { pdf } from "pdf-to-img";
it("generates a PDF", async () => {
for await (const page of await pdf("example.pdf")) {
expect(page).toMatchImageSnapshot();
}
});
// or if you want access to more details:
it("generates a PDF with 2 pages", async () => {
const doc = await pdf("example.pdf");
expect(doc.length).toBe(2);
expect(doc.metadata).toEqual({ ... });
for await (const page of doc) {
expect(page).toMatchImageSnapshot();
}
});
```
The `pdf` function accepts either a path to the file on disk, or a data URL (e.g. `data:application/pdf;base64,...`)
### Options
You can supply a second argument which is an object of options:
```js
const doc = await pdf("example.pdf", {
password: "...", // if the PDF is encrypted
scale: 2.0, // use this for PDFs with high resolution images if the generated image is low quality
});
```
```sh
npm i -g pdf-to-img@latest
pdf2img inputFile.pdf
```