【问题标题】:Why is my exec command failing but works if the command is passed in the terminal?为什么我的 exec 命令失败但如果命令在终端中传递则可以工作?
【发布时间】:2020-07-28 13:30:48
【问题描述】:

出于某种原因,我不明白为什么我的exec 命令出现问题,我相信我遵循了我正确引用的文档和示例。当我在终端中运行此命令时,我没有问题:

gitleaks --repo=https://github.com/user/repo -v --username=foo --password=bar

但是当我尝试将其编码为模块时,我可以在 package.json 中调用它:

const { exec } = require("child_process")
const test = `gitleaks --repo=https://github.com/user/repo -v --username=foo --password=bar`

const execRun = (cmd) => {
  return new Promise((resolve, reject) => {
    exec(cmd, (error, stdout, stderr) => {
      if (error) reject(error)
      resolve(stdout ? stdout : stderr)
    })
  })
}

(async () => {
try {
  const testing = await execRun(test)
  console.log(testing)
} catch (e) {
  console.log(e)
}
})()

但我继续收到错误:

{ Error: Command failed: gitleaks --repo=https://github.com/user/repo -v --username=foo --password=bar

    at ChildProcess.exithandler (child_process.js:294:12)
    at ChildProcess.emit (events.js:198:13)
    at maybeClose (internal/child_process.js:982:16)
    at Socket.stream.socket.on (internal/child_process.js:389:11)
    at Socket.emit (events.js:198:13)
    at Pipe._handle.close (net.js:606:12)
  killed: false,
  code: 1,
  signal: null,
  cmd:
   'gitleaks --repo=https://github.com/user/repo -v --username=foo --password=bar' }

我试图研究我的问题,看看我是否遗漏了什么并阅读:

为什么我的exec 命令失败,但我可以在终端中传递相同的命令并且它有效?

【问题讨论】:

  • 我检查了 gitleaks 的文档,它显示了以下退出代码:0:没有泄漏,1:存在泄漏,2:遇到错误。我想知道该命令是否为“存在泄漏”返回 1,但“exec”函数认为这是一个错误。直接在终端运行同样的命令,退出码是什么?
  • 是的,这似乎是问题所在。当我在代码 1 下控制台记录 error 时,它会转储所有泄漏信息。猜猜这意味着我需要弄清楚如何将其作为响应而不是错误,然后解决它。
  • 我的评论是否有资格作为答案?如果是这样,我可以将其添加为答案。
  • 如果您编写问题的解决方案,我会用它作为答案(重写 exec 条件化为 1 的 error.code 并解决错误信息)。这将是一个更好的问答,或者我可以回答。这样,如果有人遇到与 gitleaks 相同的问题,他们可以看到问题和解决方案。只是我的想法。

标签: node.js macos package.json gitleaks


【解决方案1】:

exec 函数运行命令时,它会检查该命令的退出代码。它假定 0 以外的退出代码是错误,因此在回调中传递错误。如果gitleaks 在回购中发现秘密,那么它会以代码 1 退出。

按照这些思路应该可以工作:

const { exec } = require("child_process")
const test = `gitleaks --repo=https://github.com/user/repo -v --username=foo --password=bar`

const execRun = (cmd) => {
  return new Promise((resolve, reject) => {
    exec(cmd, (error, stdout, stderr) => {
      if (error) {
        if (error.code === 1) {
          // leaks present
          resolve(stdout);
        } else {
          // gitleaks error
          reject(error);
        }
      } else {
        // no leaks
        resolve(stdout);
      }
    })
  })
}

(async () => {
try {
  const testing = await execRun(test)
  console.log(testing)
} catch (e) {
  console.log(e)
}
})()

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-12-28
    • 2021-01-06
    • 2021-08-18
    • 1970-01-01
    • 1970-01-01
    • 2011-06-06
    • 2016-09-09
    相关资源
    最近更新 更多