对于某些 Windows 命令,nodejs exec 命令失败,并且没有明确的错误消息

2024-04-09

我的程序中有一个编辑器,可以动态编写命令并执行它们。我想通过 child_process exec 将 myPublish 目录中的所有文件和文件夹移动到当前目录。我在 Windows 中使用 robocopy 命令。当我在 cmd 中测试 robocopy 时,它工作正常:

robocopy /s .\myPublish .\ /move

但在程序中,nodejs给出了一条不清楚的错误消息,只是说: “命令失败:robocopy /s .\myPublish .\ /move\n”


我也刚刚遇到这个问题。虽然大多数控制台应用程序在没有错误时应返回退出代码为零,但 robocopy 有一系列自定义退出代码。这使得 Node 认为执行过程中出现了错误,而实际上可能没有错误。

As per here http://www.mysidenotes.com/2008/02/15/robocopy-errorlevel-return-codes-found-in-robocopydoc/,Robocopy 具有以下组成退出代码的退出代码位:

0×10 严重错误。 Robocopy 未复制任何文件。这可能是使用错误,也可能是由于源目录或目标目录的访问权限不足而导致的错误。

0×08 某些文件或目录无法复制(发生复制错误且超出重试限制)。进一步检查这些错误。

0×04 检测到一些不匹配的文件或目录。检查输出日志。家政服务可能是必要的。

0×02 检测到一些额外的文件或目录。检查输出日志。可能需要一些家政服务。

0×01 一个或多个文件复制成功(即新文件到达)。

0×00 未发生错误,未进行复制。源目录树和目标目录树完全同步。

要解决此问题,您需要捕获错误并检查错误代码:

const cp = require('child_process');
try { 
    cp.execSync('robocopy ...'); 
} catch (err) { 
    console.log(err.status);             // get the return code
    console.log(err.output.toString());  // get robocopy's full output
}

我认为您通常会认为大于 8 的代码是更严重的错误。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

对于某些 Windows 命令,nodejs exec 命令失败,并且没有明确的错误消息 的相关文章