Lucene search
K

📄 pdf-image 2.0.0 Command Injection

🗓️ 26 Mar 2026 00:00:00Reported by Zebbern Vulnerability ResearchType 
packetstorm
 packetstorm
🔗 packetstorm.news👁 105 Views

CVE-2026-26830: pdf-image up to 2.0.0 allows OS command injection via untrusted pdfFilePath; no fix.

Related
Code
ReporterTitlePublishedViews
Family
GithubExploit
Exploit for CVE-2026-26830
24 Mar 202616:15
githubexploit
ATTACKERKB
CVE-2026-26830
25 Mar 202600:00
attackerkb
Circl
CVE-2026-26830
25 Mar 202617:08
circl
CNNVD
pdf-image 安全漏洞
25 Mar 202600:00
cnnvd
CVE
CVE-2026-26830
25 Mar 202600:00
cve
Cvelist
CVE-2026-26830
25 Mar 202600:00
cvelist
EUVD
EUVD-2026-15457
25 Mar 202615:31
euvd
Github Security Blog
pdf-image has an OS Command Injection Vulnerability through its pdfFilePath parameter
25 Mar 202615:31
github
NVD
CVE-2026-26830
25 Mar 202615:16
nvd
OSV
GHSA-Q5MH-72XG-628W pdf-image has an OS Command Injection Vulnerability through its pdfFilePath parameter
25 Mar 202615:31
osv
Rows per page
# CVE-2026-26830: OS command injection in pdf-image
    
    ## Summary
    
    `pdf-image` through version `2.0.0` allows OS command injection via
    the `pdfFilePath` argument. The package builds shell command strings
    with `util.format()` and executes them with `child_process.exec()`.
    If an application passes an attacker-controlled file path into
    `PDFImage`, shell metacharacters in that path can lead to arbitrary
    command execution.
    
    ## Affected product
    
    | Product | Affected versions | Fixed version |
    | --- | --- | --- |
    | pdf-image | all versions through 2.0.0 | no fix available as of 2026-03-24 |
    
    ## Vulnerability details
    
    - CVE ID: `CVE-2026-26830`
    - CWE: `CWE-78` - OS Command Injection
    - CVSS 3.1: `9.8` (`Critical`)
    - Vector: `CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H`
    - Affected component: `index.js`
    
    The vulnerable code path reaches `constructGetInfoCommand()` and
    `constructConvertCommandForPage()`, both of which interpolate the PDF
    path into a shell command before calling `child_process.exec()`.
    
    ## Technical impact
    
    Any application that accepts a user-controlled PDF path and passes it
    to `pdf-image` can end up executing attacker-supplied shell commands
    on the host system.
    
    ## Proof of concept
    
    ```js
    const { PDFImage } = require("pdf-image");
    
    const pdfImage = new PDFImage('test.pdf"; touch /tmp/pwned; echo "');
    pdfImage.getInfo();
    ```
    
    If the injected command runs, the process creates `/tmp/pwned`.
    
    ## Mitigation
    
    No fixed npm release is available at the time of writing.
    
    If you still depend on this package:
    
    1. Stop passing untrusted file paths into `PDFImage`.
    2. Replace shell-string construction with argument-safe process
       execution such as `execFile()` or `spawn()` with an array.
    3. Prefer a maintained alternative or a private fork with a fix.
    
    ## References
    
    - https://www.npmjs.com/package/pdf-image
    - https://github.com/mooz/node-pdf-image
    - https://github.com/mooz/node-pdf-image/blob/master/index.js

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

26 Mar 2026 00:00Current
6Medium risk
Vulners AI Score6
CVSS 3.19.8
EPSS0.00292
SSVC
105