process.env 管理 Vue 项目的环境变量(Vue项目中环境变量的配置及调用)

简述:在构建 Vue 应用时,管理配置是开发中的一个重要部分。不同的环境(如开发、测试和生产)往往需要不同的配置,例如 API、 基础 URL、第三方服务的密钥等。使用环境变量可以帮助我们更好地管理这些配置。这里将介绍如何在 Vue 项目中使用 process.env 来管理环境变量。这里来记录一下



⭐什么是 process.env?

process.env 是 Node.js 的一个全局对象,它包含了系统环境变量。这些变量可以在应用程序的运行时访问,允许开发人员根据不同的环境设置不同的配置。通过使用 process.env 管理环境变量,可以使 Node.js 应用程序的配置更加灵活和安全。


⭐为什么要在项目中使用环境变量?

环境变量在项目中的使用有多个重要原因,包括安全性、灵活性和配置管理。以下是详细解释:

1. 安全性

将敏感信息如 API 密钥、数据库密码和其他机密数据存储在环境变量中,可以显著提高应用的安全性。避免将这些敏感信息硬编码在源代码中可以减少数据泄露的风险:

  • 避免暴露机密:环境变量使得敏感信息不直接出现在代码库中,降低了信息泄露的风险。
  • 保护配置文件:通过环境变量可以避免将敏感配置暴露在版本控制系统中,从而增强了代码的安全性。

2. 灵活性

环境变量提供了灵活的配置管理方式,使得在不同的环境中使用不同的配置变得更加方便:

  • 无缝切换环境:通过设置不同的环境变量,可以轻松地在开发、测试、预生产和生产环境之间切换,而无需修改代码。
  • 减少代码修改:只需更改环境变量而不是修改代码文件,可以迅速调整配置,以适应不同的需求和环境。

3. 配置管理

环境变量提供了一种统一的配置管理方式,使得应用程序的配置更加可控和一致:

  • 集中管理:将所有环境配置集中在环境变量中,使得管理和维护配置变得更加简洁和高效。
  • 环境隔离:不同的环境可以有独立的配置文件,确保在一个环境中的设置不会影响到其他环境。
  • 简化部署:在部署时,只需根据目标环境加载相应的环境变量文件,从而简化了配置和部署过程。


⭐如何在 Vue 项目中使用环境变量?

一. 创建环境文件

在 Vue 项目根目录下,可以创建多个环境文件,例如:

.env                                    默认环境配置

.env.development               开发环境配置

.env.test:                          测试环境配置

.env.staging                        预生产环境配置

.env.production                   生产环境配置

这些文件的内容格式如下:

VUE_APP_API_URL=https://api.example.com


VUE_APP_SECRET_KEY=your_secret_key

这里所有自定义环境变量的名称必须以 VUE_APP_ 为前缀。Vue CLI 只会嵌入以 VUE_APP_ 为前缀的变量,以确保这些变量不会泄露应用程序运行时所需的其他环境变量。


二. 配置不同环境的变量

根据不同的环境,可以在相应的环境文件中配置不同的变量。例如:

.env.development 中:

VUE_APP_API_URL=https://dev.api.example.com


VUE_APP_SECRET_KEY=dev_secret_key

.env.test 中:

VUE_APP_API_URL=https://test.api.example.com


VUE_APP_SECRET_KEY=test_secret_key

.env.staging 中:

VUE_APP_API_URL=https://staging.api.example.com


VUE_APP_SECRET_KEY=staging_secret_key

.env.production 中:

VUE_APP_API_URL=https://api.example.com


VUE_APP_SECRET_KEY=prod_secret_key


三. 在 JS 文件中访问环境变量

在 Vue 组件或 JavaScript 文件中,可以通过 process.env 对象来访问这些环境变量。例如:

// 获取当前环境变量 NODE_ENV 的值,通常用于区分不同的运行环境(如开发、测试、生产)。
const env = process.env.NODE_ENV;console.log(`Running in ${env} mode`);

这里从 process.env 对象中获取名为 NODE_ENV 的环境变量的值,并将其赋值给 env 变量。这里使用模板字符串打印出当前的运行环境模式。假设 NODE_ENV 的值是 development,这行代码将输出 Running in development mode


四. 启动应用时加载环境变量

当你启动 Vue 应用时,Vue CLI 会根据当前环境自动加载相应的环境文件。例如:

npm run serve # 会加载 .env 和 .env.development 文件


npm run build # 会加载 .env 和 .env.production 文件

  • npm run serve:在开发模式下启动开发服务器时,Vue CLI 会默认加载 .env.env.development 文件。这些文件中的环境变量会在开发过程中生效,用于配置开发环境所需的参数。

  • npm run build:在构建生产版本时,Vue CLI 会默认加载 .env.env.production 文件。这些文件中的环境变量会在构建生产版本时生效,用于配置生产环境所需的参数。

当然需要额外配置,为了更好地管理不同环境的启动命令,我们可以在 package.json 中配置多种启动命令,这样可以更方便地在不同环境中启动和构建应用。以下是详细的配置方法:

配置 package.json

package.json 中配置不同环境的启动和构建命令。使用 cross-env 包来设置 NODE_ENV,以确保在不同操作系统上正确设置环境变量。

首先,安装 cross-env

npm install cross-env --save-dev

// 或者

cnpm install cross-env --save-dev

然后,在 package.json 中添加如下脚本:

{"scripts": {"serve": "vue-cli-service serve","build": "vue-cli-service build","serve:dev": "cross-env NODE_ENV=development vue-cli-service serve","serve:test": "cross-env NODE_ENV=test vue-cli-service serve","serve:staging": "cross-env NODE_ENV=staging vue-cli-service serve","serve:prod": "cross-env NODE_ENV=production vue-cli-service serve","build:dev": "cross-env NODE_ENV=development vue-cli-service build","build:test": "cross-env NODE_ENV=test vue-cli-service build","build:staging": "cross-env NODE_ENV=staging vue-cli-service build","build:prod": "cross-env NODE_ENV=production vue-cli-service build"}
}

这些命令允许你在不同环境下启动和构建应用:

  • npm run serve:dev:启动开发环境
  • npm run serve:test:启动测试环境
  • npm run serve:staging:启动预生产环境
  • npm run serve:prod:启动生产环境
  • npm run build:dev:构建开发环境
  • npm run build:test:构建测试环境
  • npm run build:staging:构建预生产环境
  • npm run build:prod:构建生产环境

然后,确保正确加载环境文件

Vue CLI 会根据 NODE_ENV 自动加载相应的环境文件。例如:

  • 如果 NODE_ENV 设置为 development,Vue CLI 会加载 .env.env.development 文件。
  • 如果 NODE_ENV 设置为 test,Vue CLI 会加载 .env.env.test 文件。
  • 如果 NODE_ENV 设置为 staging,Vue CLI 会加载 .env.env.staging 文件。
  • 如果 NODE_ENV 设置为 production,Vue CLI 会加载 .env.env.production 文件。

通过创建不同的环境文件并配置启动命令,可以在 Vue 项目中轻松管理和加载不同环境的变量。这使得应用程序的配置更加灵活和安全,适用于开发、测试、预生产和生产等不同环境。


五. 使用环境变量配置 Axios 详细

假设我们使用 Axios 进行 HTTP 请求,可以使用环境变量配置 Axios 的基础 URL。步骤如下:

1. 安装 Axios

首先,我们需要安装 Axios 作为 HTTP 客户端工具:

npm install axios
// 或者
cnpm install axios

2. 创建 Axios 实例

接下来,我们创建一个 Axios 实例,并配置基础路径:

// 该文件目录:src/utils/request.js// 引入 axios 库,用于发送 HTTP 请求
import axios from 'axios';// 创建 Axios 实例
const service = axios.create({// ⭐使用 process.env. 环境变量配置基础路径// baseURL 指定了请求的基础 URL,通常从环境变量中读取baseURL: process.env.VUE_APP_BASE_API, // 请求超时时间设置为 5000 毫秒(5 秒)timeout: 5000, // 请求超时时间
});// 请求拦截器
service.interceptors.request.use(config => {// 在请求发送之前可以对请求进行配置,如添加请求头、修改请求参数等// 例如,可以在这里添加认证 tokenreturn config;},error => {// 请求错误时,打印错误信息console.error('请求错误:', error);// 返回一个拒绝的 Promise,以便处理请求错误return Promise.reject(error);}
);// 响应拦截器
service.interceptors.response.use(response => {// 在收到响应数据后,可以对响应数据进行处理// 比如,可以在这里处理统一的响应格式return response.data;},error => {// 响应错误时,打印错误信息console.error('响应错误:', error);// 返回一个拒绝的 Promise,以便处理响应错误return Promise.reject(error);}
);// 导出 Axios 实例,以便在其他模块中使用
export default service;

这里在配置baseURL时,直接使用process.env.VUE_APP_BASE_API来设置基本路径。在启动开发服务器,运行 npm run serve 时,Vue CLI 会加载 .env.env.development 文件中的环境变量。此时,process.env.VUE_APP_BASE_API 的值会被设置为 .env.development 文件中定义的值,如果 .env.development 中没有定义,则使用 .env 文件中的值。

3. 创建 http.js 文件

并在 src/api 目录下创建一个 http.js 文件,并添加以下内容:

// 该文件目录:src/api/http.js// 引入之前创建的 Axios 实例
import request from "@/utils/request";/*** 获取图表数据的请求方法* @param {Object} data - 请求数据* @returns {Promise} - 返回一个 Promise 对象*/
export function toDaySituation(data) {return request({url: '/res/situation/overview', // API 端点,指定了请求的路径method: 'post', // 请求方法,表示使用 POST 请求data // 请求数据,传递给 API 的请求体});
}

4. 在组件中调用请求方法

接下来,我们在组件中调用 callModelType方法,来请求图表数据并处理响应。例如:

// 请入请求数据的函数
import { toDayModeltype } from '@/api/http.js';methods: {// 模型类型事件callModelType(value) {// 设置加载状态为 truethis.tableLoading = true;// 调用 PatchList 方法并传递参数toDayModeltype(this.modelParams, this.params).then((res) => {// 处理请求成功的情况if (res.code === 200) {// 设置延迟以模拟异步操作setTimeout(() => {this.tableLoading = false; // 将加载状态设置为 false}, 100);// 赋值操作,将获取的数据保存到变量const data = res.rows;     }}).catch(() => {// 处理请求失败的情况this.tableLoading = false; // 将加载状态设置为 false}).finally(() => {// 无论请求成功还是失败,都会执行这里的代码this.tableLoading = false; // 将加载状态设置为 false});},},created() {// 组件创建时调用 callModelType方法this.callModelType();
},


六. 在组件中使用环境变量

在 Vue 组件中,可以直接使用环境变量。例如:

<template><div><!-- 显示 API URL --><p>API URL: {{ apiUrl }}</p></div>
</template><script>
export default {data() {return {// 从环境变量中读取 API URLapiUrl: process.env.VUE_APP_API_URL, // 读取环境变量 VUE_APP_API_URL 的值};},
};
</script>


总结

通过在 Vue 项目中使用 process.env 管理环境变量,可以使配置管理更加灵活和安全。无论是在开发、测试、预生产还是生产环境中,环境变量都提供了一种有效的方法来管理应用程序的配置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/40441.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每天10个js面试题(二)

1.事件轮询&#xff1f; JavaScript 是单线程的&#xff0c;同一时间只能做一件事。所有任务都需要排队&#xff0c;前一个任务结束&#xff0c;才会执行后一个任务&#xff0c;为了保证任务有序的执行&#xff0c;事件轮询就是单线程任务调度的一种方式&#xff0c;单线程任务…

1014-01SF 同轴连接器

型号简介 1014-01SF是Southwest Microwave的一款2.92 mm 同轴连接器。这款连接器外壳采用钢CRES 合金 UNS S30300&#xff0c;触点采用铍铜 (BeCu)&#xff0c;UNS C17300&#xff0c;并经过金镀处理&#xff0c;以确保良好的导电性和耐腐蚀性。适用于高频微波应用&#xff0c;…

如何设计通用用户、权限、菜单数据表

在设计一个通用的用户、权限和菜单管理系统时&#xff0c;我们通常需要创建几个核心的数据库表来管理用户信息、角色信息、权限信息以及菜单信息。下面是一个基于SQL的示例&#xff0c;展示了如何建立这些基础表格。 数据库表设计 1. 用户表 (users) Sql 1CREATE TABLE user…

从 0 到 1 安装运行 Qwen2

环境信息&#xff1a; PyTorch 2.0.0 Python 3.8(ubuntu20.04) Cuda 11.8 RTX 3090(24GB) * 1 模型 /home/zhangwei/llm 源码 /usr/local/project/conda/Qwen/Qwen mkdir -p /usr/local/project/conda/Qwen #【用来存放Qwen2源码】 mkdir -p /home/zhangwei/llm #【用来存放Q…

机器人典型的交互任务、阻抗控制的示意图、内涵、意义、存在的交互控制科学问题

机器人典型的交互任务 机器人在实际应用中经常需要完成与环境的交互任务&#xff0c;这些任务包括但不限于&#xff1a; 装配任务&#xff1a;在制造业中&#xff0c;机器人需要准确地操控和组装各种零部件&#xff0c;包括不同形状、大小和材质的物体。搬运任务&#xff1a;…

科普文:一文搞懂nginx原理和实战

1. Nginx简介与核心架构 1.1 Nginx简介 Nginx (engine x) 是一个高性能的 HTTP 和反向代理服务器&#xff0c;也是一个 IMAP/POP3/SMTP 邮件代理服务器。 由 Igor Sysoev 于2004年首次发布&#xff0c;其设计目标是解决 C10K 问题&#xff0c;即在一台服务器上同时处理一万个并…

The Sandbox 人物化身每月奖励: 七月版来了!

人物化身的持有者可以从 The Sandbox 领取自己的队服&#xff01; 视频&#xff1a;https://youtu.be/tSo5FPL7DhE 我们又推出了人物化身所有者月度奖励&#xff01;在七月&#xff0c;我们将通过 The Sandbox 队服来弘扬体育竞技精神。穿上这些时尚的元宇宙队服&#xff0c;代…

Java:HashMap底层原理

一、前言 在Java 7及之前的版本中&#xff0c;HashMap的底层数据结构主要是数组加链表&#xff0c;在Java 8中&#xff0c;HashMap的底层数据结构是数组链表红黑树的组合。 二、底层数据结构 1. 数组 初始化和扩容&#xff1a;HashMap首先会初始化一个指定长度的数组&#xf…

单机多网卡互通——问题跟踪+工具分析

一、背景 想搭建soft ROCE(RXE)与实体ROCE设备互联的测试环境&#xff0c;为了节省机器以及使用方便&#xff0c;预想在配备ROCE卡的主机上&#xff0c;用另一个网卡绑定soft ROCE&#xff0c;然后互通。 [ETH1 ROCE] <--------------------> [ETH2 RXE] 二、问题跟…

Appium元素定位(全网详细讲解)(二)

1.appium inspector&#xff08;定位元素的工具&#xff09;使用方法 详细介绍&#xff1a; 详细解释&#xff1a; 图标名称说明1Show Element Handles是否显示元素句柄2Select Elements选择元素定位3Tap/Swipe By Coordinates按坐标点击/滑动4Download Screenshot下载屏幕截…

2024机器遗忘(Machine Unlearning)技术分类-思维导图

1 介绍 机器遗忘&#xff08;Machine Unlearning&#xff09;是指从机器学习模型中安全地移除或"遗忘"特定的数据点或信息。这个概念源于数据隐私保护的需求&#xff0c;尤其是在欧盟通用数据保护条例&#xff08;GDPR&#xff09;等法规中提出的"被遗忘的权利…

【漏洞复现】飞企互联-FE企业运营管理平台——SQL注入

声明&#xff1a;本文档或演示材料仅供教育和教学目的使用&#xff0c;任何个人或组织使用本文档中的信息进行非法活动&#xff0c;均与本文档的作者或发布者无关。 文章目录 漏洞描述漏洞复现测试工具 漏洞描述 飞企互联-FE企业运营管理平台是一个基于云计算、智能化、大数据…

【8】相关补充

【8】相关补充 文章目录 前言一、不同模型在测试集上的精度二、实验记录三、SNP位点筛选及其它python脚本四、总结五、后续安排总结 前言 存放一些有关这个项目研究的补充。 三叶青图像识别研究简概 一、不同模型在测试集上的精度 存放了不同识别模型在测试集上精度评估展示…

Java中的时间日期处理与时区管理

Java中的时间日期处理与时区管理 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在现代软件开发中&#xff0c;时间日期处理和时区管理是至关重要的部分。Jav…

Android HWASAN使用与实现原理

一、背景 为了提前检测出Android User Sapce的app或native进程的内存错误问题&#xff0c;帮助研发定位与分析这些问题&#xff0c;基于Android 14版本上对HWASAN做了调研分析。 二、ASAN介绍 HWASAN是在ASAN的基础上做了拓展&#xff0c;因此在介绍HWASAN之前先了解下ASAN.…

ES8.13.0 java client请求响应报错status: 200, [es/search] Failed to decode response

最近在做商城项目使用ES8.13.0做商品复杂的检索功能时&#xff0c;遇到一个报错如下&#xff1a; 2024-07-05 10:47:53.994 ERROR 10708 --- [nio-7500-exec-1] com.tfq.exception.RRExceptionHandler : co.elastic.clients.transport.TransportException: node: http://1…

WBCE CMS v1.5.2 远程命令执行漏洞(CVE-2022-25099)

前言 CVE-2022-25099 是一个影响 WBCE CMS v1.5.2 的严重安全漏洞&#xff0c;具体存在于 /languages/index.php 组件中。该漏洞允许攻击者通过上传精心构造的 PHP 文件在受影响的系统上执行任意代码。 技术细节 受影响组件&#xff1a;/languages/index.php受影响版本&…

如何在 Odoo 16 中向新视图添加字段

例如,让我们看看如何在新视图或新操作窗口中创建“many2one”字段。 请考虑下面的屏幕截图,它表示不包含任何字段的新视图类型或客户端操作窗口。 我们现在可以将与“res.partner”关联的“多对一”字段引入到我们的新视图或客户端操作窗口中。 为了实现这一点,在 XML 模板…

ShardingSphere

ShardingSphere 是一个开源的分布式数据库中间件生态系统&#xff0c;由 Apache 基金会孵化和维护。它的主要目标是帮助开发者解决分库分表、分布式事务和数据加密等分布式数据库应用中的常见问题。ShardingSphere 提供了多种组件&#xff0c;如 Sharding-JDBC、Sharding-Proxy…

Using a text embedding model locally with semantic kernel

题意&#xff1a;在本地使用带有语义核&#xff08;Semantic Kernel&#xff09;的文本嵌入模型 问题背景&#xff1a; Ive been reading Stephen Toubs blog post about building a simple console-based .NET chat application from the ground up with semantic-kernel. Im…