我有以下执行 shell 命令的脚本:
#!/usr/bin/env node
const { execSync } = require('child_process');
try {
const data = execSync(
'yarn licenses generate-disclaimer --prod',
{ encoding: 'utf8', maxBuffer: 50 * 1024 * 1024 }
);
console.log(data.length);
return true;
} catch (error) {
console.error(`Failed to generate disclaimer: ${error.message}`);
return false;
}
data
是一个包含子进程的 stdout
的 Buffer
。据我了解,将其转换为字符串的方法是使用 .toString()
方法,但在我的例子中,字符串是不完整的。我尝试执行的命令应该会产生约 500 KB 的数据,但 buffer.length
是 43741(即约 43 KB)。
问题可能是 yarn licenses
输出包含一些特殊字符,导致缓冲区不完整。如果我用 printf "%0.s-"{1..500000}
替换命令,缓冲区就完成了。
我使用的是最新的 Node 版本 (8.7.0)。
有什么想法/建议吗?
编辑:附加 | tr "\0""\n"
命令将缓冲区大小增加到 ~122 KB,所以@YaroslavAdmin 肯定是在寻找正确的方向。结果仍然不完整。如何确保转义所有特殊字符?
最佳答案
在 execSync 之后添加 .toString()
。
const data = execSync(
'yarn licenses generate-disclaimer --prod',
{ encoding: 'utf8', maxBuffer: 50 * 1024 * 1024 }
).toString(); // <<<<<<<<<<<<
关于node.js - child_process.execSync 返回的缓冲区不完整,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46818563/