Node.js中process.env问题

起因:

最近新起一个项目时候,使用NODE_ENV区分环境,在package.json中使用scripts命令。

json 复制代码
"dev": "NODE_ENV=dev && nest start --watch"

在Mac中没问题,在Windows系统中报错。

arduino 复制代码
'NODE_ENV' 不是内部或外部命令,也不是可运行的程序

解决

Windows系统不支持NODE_ENV=dev,需要用set或者cross-env

  1. 使用set解决Windows系统下问题。
lua 复制代码
npm install --save-dev cross-env
"dev": "set NODE_ENV=dev && nest start --watch",
  1. 使用cross-env跨平台设置和使用环境变量。
lua 复制代码
npm install --save-dev cross-env
"dev": "cross-env NODE_ENV=dev && nest start --watch",

注意:

1、 使用set方法,又发现代码逻辑报错。然后打印查看process.env.NODE.ENV值为"dev "

Javascript 复制代码
"dev": "set NODE_ENV=dev && nest start --watch",
console.log(process.env.NODE_ENV, process.env.NODE_ENV === 'dev','debug')
打印值 dev false debug

原来process.env.NODE_ENV值为"dev ",在&&符号前都为赋值内容,原来多了一个空格

Javascript 复制代码
"dev": "set NODE_ENV=dev&& nest start --watch",
console.log(process.env.NODE_ENV, process.env.NODE_ENV === 'dev','debug')
打印值 dev true debug

2、使用cross-env时不需要&&

Javascript 复制代码
"dev": "sross-env NODE_ENV=dev nest start --watch",
console.log(process.env.NODE_ENV, process.env.NODE_ENV === 'dev','debug')
打印值 dev false debug

cross-env原理

cross-env 是一个运行在 Node.js 环境中的工具包,它的主要作用是让我们可以在命令行中设置环境变量,而不必担心跨操作系统的兼容问题。在 Unix 和 Windows 系统中设置环境变量的方式是不同的,这就导致了我们无法写出一条在所有操作系统中都可以运行的设置环境变量的命令。cross-env 的出现就是为了解决这个问题。

以一个非常常见的场景为例,让我们来看一下在没有使用 cross-env 的情况下,如何在不同的操作系统中设置环境变量。在 Unix 系统中,我们通常会这样做:

NODE_ENV=production node app.js

而在 Windows 系统中,我们需要这样做:

set NODE_ENV=production&&node app.js

这样的差异使得我们在编写跨平台脚本时遇到了困难,因为我们无法保证所有的开发者和用户都在使用同一种操作系统。

这时,cross-env 就派上了用场。使用 cross-env,我们可以这样设置环境变量:

cross-env NODE_ENV=production node app.js

这条命令无论在 Unix 还是在 Windows 系统中,都能正确地设置 NODE_ENV 环境变量为 production。

cross-env 的工作原理是它在内部对操作系统进行了检查,并根据操作系统的类型来决定如何设置环境变量。这样,开发者就无需担心操作系统的差异,只需要专注于他们的应用程序代码。

cross-env 是一个非常小巧的工具包,但它解决了一个非常实际的问题。在实际开发中,开发者经常需要根据环境变量来改变他们的应用程序的行为。比如,在开发环境中,开发者可能希望打开一些调试日志,而在生产环境中,他们可能希望关闭这些日志。通过设置环境变量,开发者可以在不改变代码的情况下,实现这种行为的切换。

不仅如此,环境变量还常常被用来存储敏感信息,如数据库密码、API 密钥等。这些信息不应该被硬编码在代码中,而是应该存储在环境变量中,以增加应用程序的安全性。

在使用 cross-env 时,我们通常会在 package.json 文件的 scripts 字段中使用它,像下面这样:

"scripts": {"start": "cross-env NODE_ENV=production node app.js"}

然后,我们就可以通过运行 npm start 来启动我们的应用程序,而 NODE_ENV 环境变量会被设置为 production。

🎉 如果帮助到你了,请点赞支持下。😁

相关推荐
yuanlaile4 小时前
从入门到部署|2026年Koa全栈开发实战:覆盖Node.js、数据库、部署与云架构全链路
微服务·云原生·kubernetes·node.js·serverless·nodejs全栈开发
onebyte8bits5 小时前
NestJS 系列教程(十八):文件上传与对象存储架构(Multer + S3/OSS + 访问控制)
前端·架构·node.js·状态模式·nestjs
苏瞳儿5 小时前
前端/后端-配置跨域
前端·javascript·node.js·vue
SP八岐大兔6 小时前
NPM管理OpenClaw安装、卸载及运维命令
运维·前端·npm·openclaw
陈佬昔没带相机18 小时前
GitHub clone 不动、pip 卡住、brew 转圈?一份指南搞定
git·npm
码云之上21 小时前
上下文工程实战:解决多轮对话中的"上下文腐烂"问题
前端·node.js·agent
奔跑的呱呱牛1 天前
前端/Node.js操作Excel实战:使用@giszhc/xlsx(导入+导出全流程)
前端·node.js·excel·xlsx·sheetjs
Southern Wind1 天前
AI Skill Server 动态技能中台
前端·后端·mysql·node.js
米丘1 天前
Vite 代理跨域全解析:从 server.proxy 到请求转发的实现原理
javascript·node.js·vite