Handlebars provides the power necessary to let users build semantic templates. In versions 4.0.0 through 4.7.8, the Handlebars CLI precompiler (`bin/handlebars` / `lib/precompiler.js`) concatenates user-controlled strings — template file names and several CLI options — directly into the JavaScript it emits, without any escaping or sanitization. An attacker who can influence template filenames or CLI arguments can inject arbitrary JavaScript that executes when the generated bundle is loaded in Node.js or a browser. Version 4.7.9 fixes the issue. Some workarounds are available. First, validate all CLI inputs before invoking the precompiler. Reject filenames and option values that contain characters with JavaScript string-escaping significance (`"`, `'`, `;`, etc.). Second, use a fixed, trusted namespace string passed via a configuration file rather than command-line arguments in automated pipelines. Third, run the precompiler in a sandboxed environment (container with no write access to sensitive paths) to limit the impact of successful exploitation. Fourth, audit template filenames in any repository or package that is consumed by an automated build pipeline.
We have discovered 27,902 live websites that are affected by CVE-2026-33941.
| Product | |
| Category | JavaScript Frameworks |
| Vulnerable Domains | 27,902 live websites (90% of Handlebars install base) |
| Vulnerable Versions |
|
| Vulnerable Versions Count | 34 versions ( 68% of all versions) |
| 19,799 websites | |
| 857 websites | |
| 832 websites | |
| 674 websites | |
| 523 websites | |
| 391 websites | |
| 344 websites | |
| 342 websites | |
| 337 websites | |
| 300 websites |
| .com | 16,791 websites |
| .org | 2,218 websites |
| .ca | 727 websites |
| .net | 673 websites |
| .de | 575 websites |
| .co.uk | 467 websites |
| .com.au | 452 websites |
| .edu | 421 websites |
| .pl | 310 websites |
| .it | 269 websites |
| Domain | Country | Rank | Contacts |
|---|---|---|---|
| ***.***.*******.com | *,*** | ||
| ************.**.uk | *,*** | ||
| *************.com | *,*** | ||
| *****.blog | *,*** | ||
| ******.edu | *,*** | ||
| *************.com | *,*** | ||
| *****.com | **,*** | ||
| ****.com | **,*** | ||
| **********.**.uk | **,*** | ||
| ******.com | **,*** |
FAQ