nodejs 沙箱环境 vm

本文探讨了Node.js的内置`vm`模块,用于在安全环境中执行用户提供的JavaScript代码。通过`vm.Script`和`vm.runInContext`方法,可以创建和运行代码实例。文章提到了如何获取异步代码的结果,以及如何设置代码运行时间限制。此外,还强调了定制`context`的安全风险,并推荐了如`vm2`等第三方库来增强安全性。在生产环境中,建议结合子进程和底层资源限制来进一步确保安全。
摘要由CSDN通过智能技术生成

原文链接: nodejs 沙箱环境 vm

上一篇: lerna 代码管理模式

下一篇: css overflow overlay 的特性

文档

http://nodejs.cn/api/vm.html

vm2 一个类似的第三方库

https://github.com/patriksimek/vm2

在一些系统中,我们希望给用户提供插入自定义逻辑的能力,除了 RPC REST 之外,运行客户提供的代码也是比较常用的方法,好处是可以极大地减少在网络上的耗时。JavaScript 是一种非常流行而且容易上手的语言,因此,让用户用 JavaScript 来写自定义逻辑是一个不错的选择。下面我们介绍 Node.js 提供的 vm 模块以及分析用它来运行不信任代码可能遇到的问题。

vm 模块

vm 模块是 Node.js 内置的核心模块,它能让我们编译 JavaScript 代码和在指定的环境中运行。请看下面例子:

const util = require('util');
const vm = require('vm');

// 1. 创建一个 vm.Script 实例, 编译要执行的代码
const script = new vm.Script('globalVar += 1; anotherGlobalVar = 1; ');
// 2. 用于绑定到 context 的对象
const sandbox = {globalVar: 1};
// 3. 创建一个 context, 并且把 sandbox 这个对象绑定到这个环境, 作为全局对象
const contextifiedSandbox = vm.createContext(sandbo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值