环境变量里面的.env文件是如何起作用的?

1. 配置文件的加载机制:

让我们看看代码中是如何处理这些配置文件的:

js 复制代码
// src/config/index.js 中的代码
const loadEnv = () => {
  const env = process.env.NODE_ENV || 'development';  // 获取当前环境
  const envPath = path.resolve(process.cwd(), `.env.${env}`);  // 根据环境选择配置文件
  
  dotenv.config({ path: envPath });  // 加载对应的配置文件
};

通过path.resolve(process.cwd(),.env.${env}); 获取到环境变量的文件,然后读取信息。

2. 环境切换机制:

在 package.json 中定义了不同环境的启动命令:

js 复制代码
{
  "scripts": {
    "dev": "cross-env NODE_ENV=development nodemon src/app.js",    // 开发环境
    "start": "cross-env NODE_ENV=production node src/app.js"       // 生产环境
  }
}

工作流程:

  1. 开发环境(执行 npm run dev):
  • 设置 NODE_ENV=development
  • 加载 .env.development 文件
  • 使用 nodemon 启动服务(支持热重载)
  • 输出详细的调试信息
  • 使用本地数据库配置
  1. 生产环境(执行 npm start):
  • 设置 NODE_ENV=production
  • 加载 .env.production 文件
  • 使用 node 直接启动服务
  • 只输出重要的日志信息
  • 使用生产环境数据库配置

3. 配置文件的使用:

在代码中通过 process.env 来使用这些配置,例如:

js 复制代码
// src/config/db.js 中的数据库配置
const sequelize = new Sequelize({
  dialect: 'mysql',
  host: process.env.DB_HOST,        // 使用配置文件中的数据库主机
  port: process.env.DB_PORT,        // 使用配置文件中的数据库端口
  database: process.env.DB_NAME,    // 使用配置文件中的数据库名
  username: process.env.DB_USER,    // 使用配置文件中的用户名
  password: process.env.DB_PASSWORD // 使用配置文件中的密码
});

// src/app.js 中的跨域配置
app.use(cors({
  origin: process.env.CORS_ORIGIN,  // 使用配置文件中的跨域配置
  credentials: true
}));
  1. 安全考虑:
  • 这两个文件都在 .gitignore 中,不会被提交到代码仓库
  • 生产环境的敏感信息(如密码、密钥)应该通过安全的方式管理
  • 配置文件中的值可以被环境变量覆盖

使用示例:

js 复制代码
# 开发环境启动
npm run dev
# 此时会加载 .env.development 的配置
# 使用 nodemon 启动,支持热重载

# 生产环境启动
npm start
# 此时会加载 .env.production 的配置
# 使用 node 直接启动,不支持热重载
相关推荐
不会敲代码14 小时前
手写 Mini React:从 JSX 到虚拟 DOM 再到 render,搞懂 React 底层原理
前端·javascript·react.js
kyriewen5 小时前
你的代码仓库变成“毛线团”了?Monorepo 用 Turborepo 拆成“乐高积木”
前端·javascript·面试
身如柳絮随风扬5 小时前
你知道什么是 Ajax 吗?—— 从入门到原理,一篇彻底搞懂
前端·ajax·okhttp
旷世奇才李先生6 小时前
Vue3\+TypeScript 2026实战——企业级前端项目架构搭建与性能优化全指南
前端·架构·typescript
Beginner x_u6 小时前
前端八股整理(工程化 02)|CommonJS/ESM、Webpack Loader/Plugin 与Vite 对比
前端·webpack·node.js·plugin·loader
openKaka_7 小时前
createRoot 到底创建了什么:FiberRootNode 和 HostRootFiber 的初始化过程
前端·javascript·react.js
习明然7 小时前
UniApp开发体验感受总结
前端·uni-app
刀法如飞8 小时前
Claude Code Skills 推荐:2026年最值得安装的10个AI技能
前端·后端·ai编程
Lee川8 小时前
面试手写 KeepAlive:React 组件缓存的实现原理
前端·react.js·面试
墨染天姬9 小时前
【AI】cursor提示词小技巧
前端·数据库·人工智能