javascript - 为什么 JS 中的类/函数构造函数将字符串计算为表达式?

标签 javascript node.js security

我查看了 eslint-plugin-security 中的一条规则并发现用户输入理论上可能会导致远程代码执行错误。

const a = class {};
console.log(a['constructor']);
a['constructor']('console.log(1)')();

function b() {}
console.log(b['constructor']);
b['constructor']('console.log(2)')();

const c = {}
console.log(c['constructor'])
console.log(c['constructor']('console.log(3)')());

从代码片段中很容易看出类和函数的构造函数似乎解析字符串并将它们评估为有效代码。由于某种原因,对象不会表现出这种行为。

为什么会允许这种情况发生? JavaScript 的哪些功能需要函数/类构造函数的这种行为?我假设它是 JavaScript 工作方式不可或缺的一部分,否则我不明白为什么它没有从语言中删除。

最佳答案

问题是类的 .constructorFunction,使用字符串调用 Function 构造函数会从该字符串创建一个函数,然后调用该函数结果是执行字符串的代码:

const a = class {};
console.dir(a['constructor'] === Function);
a['constructor']('console.log(1)')();

这实际上与

没有什么不同

Function('console.log(1)')();

只是类的constructor属性碰巧指向同一个东西。

如果您两次导航到 .constructor 属性(第一个访问 Object 构造函数,第二个访问 Function 构造函数):

const a = {};
console.dir(a['constructor'].constructor === Function);
a['constructor'].constructor('console.log(1)')();

如果您允许任意访问任何对象的属性,并且还允许使用任意参数调用这些属性,则几乎可以执行任何操作。原型(prototype)链(和 .constructor)属性很有用,但像许多东西一样,它们可能会被滥用。

关于javascript - 为什么 JS 中的类/函数构造函数将字符串计算为表达式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60113342/

相关文章:

javascript - jQuery 表行切换显示/隐藏与按钮关联

javascript - Rich文本输入框-溢出问题

node.js - 带有 passportjs + Vue 的 Google oAuth

security - 有哪些好的 SharePoint 安全资源?

python - 从头开始了解 CGI 和 SQL 安全性

javascript - HTML5 Canvas 变换与手动偏移?

javascript - 更改 jQuery UI 按钮大小?

javascript - 带有 express 和 websocket 的 Node.js 在 WebSocket 握手期间给出错误 : Unexpected response code: 200

javascript - 我可以在循环内使用 res.send() node.js 方法吗?

security - "Bobby Tables"XKCD 漫画中的 SQL 注入(inject)是如何工作的?