[英]process.env.PORT from dotenv causes EACESS: permission denied error in node
所以我刚刚在我的项目中安装了 dotenv 并且我需要使用以下代码:
require("dotenv").config();
然后像这样使用我的变量:
app.listen(process.env.PORT, () => {
console.log(`Listening on ${process.env.ENDPOINT}:${process.env.PORT}`);
});
在 .env 中:
ENDPOINT = "127.0.0.1";
PORT = 5000;
如果我将变量作为常量添加到我的 js 文件中,代码就可以正常工作,但是当我尝试通过 process.env 访问变量时,我得到:
events.js:291 抛出 er; // 未处理的“错误”事件 ^
错误:听 EACCES:权限被拒绝 5000; 在 Server.setupListenHandle [as _listen2] (net.js:1299:21) at listenInCluster (net.js:1364:12) at Server.listen (net.js:1461:5) at Function.listen (C:\\Users \\Darkbound\\Desktop\\TouchScreenProject\\SmartFactory\\server\\node_modules\\express\\lib\\application.js:618:24) 在 Object. (C:\\Users\\Darkbound\\Desktop\\TouchScreenProject\\SmartFactory\\server\\main.js:34:5) 在 Module._compile (internal/modules/cjs/loader.js:1251:30) 在 Object.Module._extensions。 .js (internal/modules/cjs/loader.js:1272:10) 在 Module.load (internal/modules/cjs/loader.js:1100:32) 在 Function.Module._load (internal/modules/cjs/loader .js:962:14) at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:72:12) at internal/main/run_main_module.js:17:47 在服务器实例上发出“错误”事件:在emitErrorNT (net.js:1343:8) at processTicksAndRejections (internal/process/task_queues.js:80:21) { 代码:'EACCES',
错误号:-4092,系统调用:'listen',地址:'5000;',端口:-1 }
我尝试使用其他端口,但在所有端口上都出现相同的错误,我尝试了 3000、3010、5000 等。
如果另一个变量ENDPOINT
访问没有问题,所以如果我这样做:
const PORT = 5000;
app.listen(PORT, () => {
console.log(`Listening on ${process.env.ENDPOINT}:${PORT}`);
});
这有效。
编辑解决:像往常一样,在我提出问题后,我发现了这个问题。 问题是我有;
在 .env 文件中每个变量的末尾。 发生这种情况是因为我从我的 javascript 复制/粘贴了变量,我只删除了const
但忘记了;
像往常一样,我在提出问题后立即发现了这个问题。 问题是我有;
在.env
文件中每个变量的.env
。 发生这种情况是因为我从我的 javascript 复制/粘贴了变量,我只删除了const
但忘记了;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.