如何在 Node.js 中使用 .env 文件管理环境变量 ?

Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法,而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要,以及如何在 Node.js 应用程序中有效的使用它。

为什么使用 .env 文件 ?

Security

在源代码中保留敏感信息 (如 API 密钥、数据库凭据) 可能会将它们暴露给意想不到的访问者。将此数据分离到特定于环境的文件中,您可以使用 .gitignore 轻松地将其排除在版本控制之外。

Configurability

随着应用程序的迭代增长,它们可能需要针对不同环境 (开发、测试、生产) 使用不同配置。使用 .env 文件有助于在配置和代码之间保持清晰的分离。

Portability

通过在代码中引用环境变量,您可以维护一个易于在不同环境之间移动的一致的代码库,只需要更新 .env 文件或给定部署的实际环境变量。

如何在 Node.js 中使用 .env 文件

1. Creating the .env file

在项目的根目录中创建一个 .env 文件,环境变量定义:key = value

env 复制代码
DATABASE_URL=mongodb://localhost:27017/mydb
SECRET_KEY=my-secret-key
API_KEY=abcdef123456

2. Ignoring the .env file

为了防止你的 .env 文件提交到存储库,将其添加到 .gitignore 文件中。

gitignore 复制代码
# .gitignore
node_modules/
.env

3. Reading the .env file in your application

Node.js 应用程序访问 .env 文件中定义的变量,通常会使用 dotenv 软件包。

复制代码
npm install dotenv

在主应用程序文件的顶部(通常是 index.js 或 server.js),导入并配置 dotenv

javascript 复制代码
require('dotenv').config();

console.log(process.env.DATABASE_URL); // Outputs: mongodb://localhost:27017/mydb

通过调用 dotenv.config().env 文件中的所有变量加载到 process.env,它们在整个应用程序中都可以访问。

4. Using environment variables in the application

既然已经加载了环境变量,就可以在整个应用程序中使用它们了。例如,当连接到 MongoDB 实例时

javascript 复制代码
const mongoose = require('mongoose');

mongoose.connect(process.env.DATABASE_URL, { useNewUrlParser: true, useUnifiedTopology: true });

或者在配置 API 时

javascript 复制代码
const apiKey = process.env.API_KEY;

最佳实践

Never commit your .env file:

一定要确保 .env 文件被添加到你的 .gitignore 文件中。

Use descriptive variable names

清晰的名称使团队成员更容易理解每个变量的用途。

Provide a .env.example

与其共享 .env 文件,不如创建一个 .env.example 文件,包含所有键但不包含值,这可以作为团队成员或部署的模板。

Use fallbacks

有时,您可能希望在缺少环境变量的情况下提供一个默认值。

javascript 复制代码
const apiKey = process.env.API_KEY || 'default-api-key';

Don't over-rely on .env

对于较大的应用程序或微服务架构,请考虑使用专用的配置管理系统或服务。

我的开源项目

相关推荐
MetaverseMan12 小时前
Rust Tokio 和 Node.js 异步的相似之处
开发语言·rust·node.js
腥臭腐朽的日子熠熠生辉12 小时前
nvm 安装某个node.js版本后不能使用或者报错,或不能使用npm的问题
前端·npm·node.js
前端小张同学15 小时前
前端Vue后端Nodejs 实现 pdf下载和预览,如何实现?
前端·javascript·node.js
初学者7.16 小时前
Webpack总结
前端·webpack·node.js
OpenTiny社区18 小时前
Node.js技术原理分析系列6——基于 V8 封装一个自己的 JavaScript 运行时
前端·node.js
黄毛火烧雪下19 小时前
使用CRACO自定义 Webpack 配置
前端·webpack·node.js
不想说话的麋鹿19 小时前
「项目实战」从0搭建NestJS后端服务(二):数据库选型和Prisma整合
前端·node.js
NoneCoder21 小时前
Node.js系列(4)--微服务架构实践
微服务·架构·node.js
eli9601 天前
node-ddk, electron 组件, 操作窗口
前端·javascript·electron·node.js
zooKevin1 天前
腾讯云宝塔安装ffmpeg
ffmpeg·node.js·腾讯云