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 等安全报告。

相关推荐
tuanyuan99o12 小时前
2026商城小程序的安全怎么保障?防止黑客攻击和数据泄露
安全·小程序
pusheng202512 小时前
IFSJ全英文专访:中国创新力量重塑先进气体感知技术,赋能全球关键基础设施安全
前端·网络·人工智能·物联网·安全
147API13 小时前
Project Glasswing 扩展后,AI 安全扫描不能只看发现漏洞
人工智能·安全·api·claude
KKKlucifer14 小时前
AI赋能安全运营,构建闭环数据风险防御体系
人工智能·安全
黎阳之光15 小时前
数智赋能水厂全链路安全|黎阳之光以视频孪生技术落地供水精细化管控
人工智能·物联网·算法·安全·数字孪生
常宇杏起在16 小时前
AI安全专项:AI密码技术的应用与安全防护
人工智能·安全
Raink老师16 小时前
【AI面试临阵磨枪-94】Skill 安全:注入、越权、数据泄露、恶意代码、沙箱?
数据库·安全·面试
Bruce_Liuxiaowei16 小时前
2026年6月第1周网络安全形势周报
人工智能·安全·web安全·ai·智能体
AI创界者16 小时前
【网络安全】图形化玩转 Hashcat:GUI 界面部署与实战密码审计指南
安全·web安全
米丘17 小时前
浏览器 本地存储 (cookie 、sessionStorage、localStorage)
安全·http·浏览器