我有一个以下格式的存储库:
-> /
-> client/
-> server/
-> package.json
-> index.js
-> package.json
在根文件夹的package.json中,我有一个如下的启动脚本:
"start": "node server/index.js"
在服务器文件夹下的package.json中,我有一个如下的启动脚本:
"start": "nodemon --exec node index.js"
当我进入服务器文件夹并运行启动命令时,什么都没有中断。但是当我运行 从根级别package.json启动命令,出现以下错误:
internal/fs/utils.js:425
throw new ERR_INVALID_ARG_TYPE(propName, ['string', 'Buffer', 'URL'], path);
^
TypeError [ERR_INVALID_ARG_TYPE]: The "path" argument must be one of type string, Buffer, or URL. Received type undefined
at Object.openSync (fs.js:446:3)
at Object.readFileSync (fs.js:354:35)
at Object.<anonymous> (I:\datum_mui\server\index.js:131:13)
at Module._compile (internal/modules/cjs/loader.js:759:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:770:10)
at Module.load (internal/modules/cjs/loader.js:628:32)
at Function.Module._load (internal/modules/cjs/loader.js:555:12)
at Function.Module.runMain (internal/modules/cjs/loader.js:824:10)
at internal/main/run_main_module.js:17:11
npm ERR! code ELIFECYCLE
npm ERR! errno 1
我不确定是什么原因造成的。有人可以启发我有关幕后发生的事情吗?
编辑
我将错误范围缩小到了index.js
if (nodeEnv === 'local'){
app.listen(getPort(nodeEnv));
} else{
https.createServer({
key: fs.readFileSync(getKeyFilePath(nodeEnv)),
cert: fs.readFileSync(getCertFilePath(nodeEnv))
}, app).listen(getPort(nodeEnv));
}
事实证明,方法getKeyFilePath()
和getCertFilePath()
返回null并导致fs模块跳闸。
我自动假定因为存在if-else语句,所以我永远不会遇到这样的问题。但是事实证明我会的。
虽然很奇怪,但是当我在服务器文件夹中时正常工作,但是当我不在服务器文件夹中时,会出现此错误。