问题描述
-> /
-> 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语句,所以我永远不会遇到这样的问题。但是事实证明我会的。
虽然很奇怪,但是当我在服务器文件夹中时正常工作,但是当我不在服务器文件夹中时,会出现此错误。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)