Node.js 沙箱库 vm2 曝高危沙箱逃逸漏洞(CVE-2026-22709)

近日,热门 Node.js 沙箱库 vm2 被披露一个高危漏洞(CVE-2026-22709,CVSS 评分 9.8,Critical)。攻击者可利用该漏洞轻松突破沙箱限制,在底层主机系统上执行任意代码(RCE)。

vm2 是一款开源库,主要用于创建安全的 JavaScript 执行环境它允许开发者运行不受信任的代码,同时限制其对文件系统等资源的访问,是实现代码隔离的常用工具。

What is Sandboxing? Understand Sandboxing in Cyber Security - OPSWAT

该库广泛应用于支持用户脚本的 SaaS 平台、在线代码运行工具、聊天机器人以及众多开源项目中。GitHub 上使用 vm2 的项目超过 20 万个,npm 周下载量长期稳定在百万次级别(目前最新版本为 3.10.5)。

漏洞根源Promise 回调清理机制存在缺陷

漏洞核心在于 vm2 对异步操作 Promise 的隔离不够完善。

  • vm2 会对自身内置 Promise 的回调函数进行数据清理(sanitization)。
  • 但异步函数返回的是全局 Promise 对象,其 .then() 和 .catch() 回调函数未能得到充分的清理校验。
  • 攻击者可通过覆盖 Function.prototype.call 等方式绕过清理,导致沙箱逃逸。

维护者明确指出:在 vm2 3.10.0 版本中,Promise.prototype.then 和 Promise.prototype.catch 的回调清理机制可被绕过,从而允许任意代码执行。

官方已修复

  • 3.10.1 版本进行了部分修复。
  • 3.10.2 版本进一步强化措施,避免绕过。
  • 目前推荐升级至 最新版本 3.10.5(或至少 3.10.2),所有已知漏洞均已修复。

开发者还公开了 PoC 演示代码,展示了如何在沙箱内触发漏洞并执行主机命令。鉴于利用方式简单,官方强烈建议所有用户立即升级

Threat actors misuse Node.js to deliver malware and other malicious payloads | Microsoft Security Blog

已发布的漏洞利用片段(示例简化示意)

JavaScript

复制代码
// 简化概念示例(实际 PoC 更具体,请参考官方 advisory)
const { VM } = require("vm2");
const vm = new VM();

vm.run(`
  // 攻击代码:覆盖原型,绕过 Promise 清理
  // ...(完整 PoC 见 GitHub Security Advisory)
`);

建议:不要在生产环境中直接运行未经验证的演示代码。

vm2 的历史沙箱逃逸问题

vm2 长期以来沙箱逃逸漏洞频发,曾在 2023 年宣布停止维护,并被判定"不适合运行不受信任代码"。2023 年 10 月项目重启,发布 3.10.0 版本修复当时已知问题并保持向下兼容(至 Node 6)。

历史高危漏洞包括:

  • CVE-2022-36067:允许突破隔离执行主机命令。
  • CVE-2023-29017:利用程序迅速公开。
  • CVE-2023-30547:同月披露的另一沙箱逃逸漏洞。
  • 以及其他多个类似问题。

尽管多次修复,但此次 CVE-2026-22709 再次提醒开发者:沙箱库的安全边界极易被复杂异步机制突破。

安全建议
  1. 立即升级 :将 vm2 更新至 3.10.5 (或至少 3.10.2):

    Bash

    复制代码
    npm install vm2@latest
  2. 替代方案:考虑使用更安全的隔离工具,如 isolated-vm(官方曾推荐)或其他基于虚拟化/进程隔离的方案。

  3. 最佳实践 避免在高风险场景下运行完全不受信任的代码结合静态分析、权限最小化等防御措施。

  4. 监控依赖 :定期使用 Snyk、Dependabot 等工具检查项目中的 vm2 版本

参考来源:GitHub Security Advisory、NVD、The Hacker News 等安全报告。

相关推荐
一名优秀的码农5 小时前
vulhub系列-84-hacksudo: aliens(超详细)
安全·web安全·网络安全·网络攻击模型·安全威胁分析
Data-Miner6 小时前
41页精品PPT|AI大模型安全架构构建与落地实践解决方案
人工智能·安全·安全架构
nashane7 小时前
HarmonyOS 6学习:加密一致性与安全存储——AES GCM排查与SaveButton实践
学习·安全·harmonyos·harmony app
数智化精益手记局7 小时前
什么是仓库安灯管理系统?一文讲清仓库安灯管理系统的核心概念
大数据·网络·人工智能·安全·精益工程
Flittly8 小时前
【SpringSecurity新手村系列】(7)基于资源权限码(Authority)的接口权限控制实战
java·spring boot·安全
alxraves9 小时前
医疗器械管代的职责
安全·健康医疗·制造
alxraves9 小时前
医疗器械质量管理体系信息系统的需求
大数据·安全·健康医疗·制造
feng14569 小时前
稳定性-资金安全和资损防控
运维·网络·安全
福大大架构师每日一题11 小时前
openclaw v2026.4.21 更新:图像生成、权限安全、插件修复、Slack 线程、浏览器与 npm 安装全面优化
前端·安全·npm
李日灐11 小时前
<5> Linux 开发工具:包管理 + Vim 实操 + GCC 编译流程 + 静态与动态链接详解
linux·运维·服务器·面试·vim·gcc