广安建设机械网站/合肥网络营销公司
简述:在构建 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
管理环境变量,可以使配置管理更加灵活和安全。无论是在开发、测试、预生产还是生产环境中,环境变量都提供了一种有效的方法来管理应用程序的配置。
相关文章:

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

算法工程师第六天(● 454.四数相加II ● 383. 赎金信 ● 15. 三数之和 ● 18. 四数之和 ● 总结 )
参考文献 代码随想录 一、四数相加 II 给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足: 0 < i, j, k, l < nnums1[i] nums2[j] nums3[k] nums4[l] 0 示例 1&#…...

笔记:Newtonsoft.Json 自定义一个根据typeconverter转换的JsonConverter
在 Newtonsoft.Json 中创建一个根据 TypeConverter 转换的 JsonConverter 允许你在序列化和反序列化过程中利用 .NET 的 TypeConverter 机制。这种方式特别有用,当你想要为不直接支持 JSON 序列化的类型提供自定义的序列化逻辑时,比如第三方库中的类型或…...

第241题| 确定极限中参数问题 | 武忠祥老师每日一题
解题思路:确定极限中的参数的方法是求这个极限;求极限根据类型选方法。 形可以用到三种方法:洛必达,等价,泰勒。 先观察题目,将看成一个整体,同时,并令,整理之后如下: 这里也要想办…...

线程池【开发实践】
文章目录 一、为什么要用线程池1.1 单线程的问题1.2 手动创建多线程的问题1.3 线程池的作用(优点)1.4 线程池的使用场景 二、线程池的基础知识2.1 线程池的核心组件2.2 JUC中的线程池架构2.3 线程池的配置参数2.4 线程池常见的拒绝策略(可自定…...

论文辅助笔记:ST-LLM
1 时间嵌入 2 PFA(Partial Frozen Architecture) 3 ST_LLM 3.1 初始化 3.2 forward...

加入运动健康数据开放平台,共赢鸿蒙未来
HarmonyOS SDK运动健康服务(Health Service Kit)是为华为生态应用打造的基于华为帐号和用户授权的运动健康数据开放平台。在获取用户授权后,开发者可以使用运动健康服务提供的开放能力获取运动健康数据,基于多种类型数据构建运动健…...

企业化运维(7)_Zabbix企业级监控平台
官网:Zabbix :: The Enterprise-Class Open Source Network Monitoring Solution ###1.Zabbix部署### (1)zabbix安装 安装源 修改安装路径为清华镜像 [rootserver1 zabbix]# cd /etc/yum.repos.d/ [rootserver1 yum.repos.d]# vim zabbix.r…...

CTF php RCE (一)
0x01 引言 首先进入题目 应该是大部分都是一段白盒PHP审计,然后我们为了命令执行,绕过或者是钻空子等等操作,来拿到flag 0x02 基础 0x01 传参方式 这里有两个工具,hackbar和burpsuite,这两个工具非常实用 大家可以自己Googl…...

Proteus + Keil单片机仿真教程(五)多位LED数码管的静态显示
Proteus + Keil单片机仿真教程(五)多位LED数码管 上一章节讲解了单个数码管的静态和动态显示,这一章节将对多个数码管的静态显示进行学习,本章节主要难点: 1.锁存器的理解和使用; 2.多个数码管的接线封装方式; 3.Proteus 快速接头的使用。 第一个多位数码管示例 元件…...

【Linux】网络新兵连
欢迎来到 破晓的历程的 博客 ⛺️不负时光,不负己✈️ 引言 在上一篇博客中,我们简单的介绍了一些Linux网络一些比较基本的概念。本篇博客我们将开始正式学习Linux网络套接字的内容,那么我们开始吧! 1.网络中的地址管理 大家一…...

基于STM32的智能加湿器
1.简介 基于STM32的加湿器发展前景非常乐观,这主要得益于其在技术、市场需求、应用场景以及政策支持等多方面的优势。STM32微控制器具备强大的处理能力和丰富的外设接口,能够实现精确的湿度监测和智能化控制。基于STM32的加湿器可以根据环境湿度自动调节…...

ubuntu 如何解压tar
在Ubuntu中解压.tar文件,可以使用tar命令。以下是解压.tar文件的命令: tar -xvf file.tar 解释: x 表示解压 v 表示显示过程中的详细信息(可选) f 表示后面跟文件名 这将在当前目录下解压file.tar文件的内容。如果…...

C++ 算法——二分查找
如果要你在一个升序序列中查找一个值的位置,你是否还会傻乎乎的用下面这个 O ( n ) \mathcal O(n) O(n) 的代码暴力查找,如果是,我告诉你,其实根本不用这么做。 int find(int a[],int n,int k) {for(int i0;i<n;i) if(a[i]k)…...

【自动驾驶仿真在做什么——初学者总结(陆续补充)】
文章目录 基础概念自动驾驶级别再稍提一下ODD是什么? 自动驾驶仿真分类软件在环仿真硬件仿真 仿真究竟难在哪?关于lidar和radar区别一些名词解释 最近也是学习自动驾驶仿真相关知识,习惯去总结一下,方便自己回顾和总结,…...

探索HTML5的设计原则:引领Web开发的未来方向
随着互联网的飞速发展,HTML5作为Web技术的核心标准之一,不仅极大地丰富了网页的表现力和交互性,还推动了Web应用向更加动态、高效、安全的方向迈进。HTML5的设计原则,体现了对用户体验、内容可访问性、跨平台兼容性以及未来可扩展…...

力扣喜刷刷--day1
1.无重复字符的最长子串 知识点:滑动窗口 基本概念 窗口:窗口是一个连续的子序列,可以是固定长度或可变长度。滑动:窗口在数据序列上移动,可以是向左或向右。边界:窗口的起始和结束位置。 应用场景 字符…...

配置linux的yum镜像为阿里镜像源
1.备份当前的yum源 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 2.下载新的CentOS-Base.repo 到/etc/yum.repos.d wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo 3.清空并生成缓存 yum clean …...

react使用markdown进行展示
有一些文档非常长,但是又要挨个设置样式,直接用 组件库 - marked 注意文档要放在public下才能读取。但非常方便 import { marked, Renderer } from "marked".....const [html, setHtml] useState<any>("")const renderer:…...

实时温湿度监测系统:Micropython编码ESP32与DHT22模块的无线数据传输与PC端接收项目
实时温湿度监测系统 前言项目目的项目材料项目步骤模拟ESP32接线连接测试搭建PC端ESP32拷录环境对ESP32进行拷录PC端搭建桌面组件本地数据接收桌面小组件部分 实验总结 前言 人生苦短,我用Python。 由于我在日常工作中经常使用Python,因此在进行该项目…...

CloudWatch Logs Insights 详解
CloudWatch Logs Insights 是 AWS 提供的强大日志分析工具,允许您快速、交互式地搜索和分析日志数据。本文将详细介绍使用 CloudWatch Logs Insights 所需的权限、常用查询方法,以及一些实用的查询示例。 1. 所需权限 要使用 CloudWatch Logs Insights,用户需要具备以下 I…...

Jmeter在信息头中设置Bearer与 token 的拼接值
思路:先获取token,将token设置成全局变量,再与Bearer拼接。 第一步:使用提取器将token值提取出来,使用setProperty函数将提取的token值设置成全局变量,在登录请求后面添加BeanShell取样器 或者 BeanShell后…...

C#程序调用Sql Server存储过程异常处理:调用存储过程后不返回、不抛异常的解决方案
目录 一、代码解析: 二、解决方案 1、增加日志记录 2、异步操作 注意事项 3、增加超时机制 4、使用线程池 5、使用信号量或事件 6、监控数据库连接状态 在C#程序操作Sql Server数据库的实际应用中,若异常就会抛出异常,我们还能找到异…...

数据统计与数据分组18-25题(30 天 Pandas 挑战)
数据统计与数据分组 1. 知识点1.18 分箱与统计个数1.19 分组与求和统计1.20 分组获取最小值1.21 分组获取值个数1.22 分组与条件查询1.23 分组与条件查询及获取最大值1.24 分组及自定义函数1.25 分组lambda函数统计 2. 题目2.18 按分类统计薪水(数据统计)…...

Apache Seata应用侧启动过程剖析——注册中心与配置中心模块
本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 Apache Seata应用侧启动过程剖析——注册中心与配置中心模块 前言 在Seata的应用侧…...

大话光学原理:1.“实体泛光说”、反射与折射
一、实体泛光说 在古希腊,那些喜好沉思的智者们中,曾流传着一个奇妙的设想:他们认为,我们的眼睛仿佛伸出无数触手般的光线,这些光线能向四面八方延伸,紧紧抓住周围的每一个物体。于是,当我们凝视…...

住宅代理、移动代理和数据中心代理之间的区别
如果您是一名认真的互联网用户,可能需要反复访问某个网站或服务器,可能是为了数据抓取、价格比较、SEO 监控等用例,而不会被 IP 列入黑名单或被 CAPTCHA 阻止。 代理的工作原理是将所有传出数据发送到代理服务器,然后代理服务器将…...

光学传感器图像处理流程(一)
光学传感器图像处理流程(一) 1. 处理流程总览2. 详细处理流程2.1. 图像预处理2.1.1. 降噪处理2.1.2. 薄云处理2.1.3. 阴影处理 2.2. 辐射校正2.2.1. 辐射定标2.2.2. 大气校正2.2.3. 地形校正 2.3. 几何校正2.3.1. 图像配准2.3.2. 几何粗校正2.3.3. 几何精…...

el-table 树状表格查询符合条件的数据
需要对el-table的树状表格根据输入机构名称,筛选出符合条件的数据,可用如下方法: 页面内容如下: <el-input v-model"ogeName" placeholder"请输入机构名称"><el-table :data"list" row…...

MQTT教程--服务器使用EMQX和客户端使用MQTTX
什么是MQTT MQTT(Message Queuing Telemetry Transport)是一种轻量级、基于发布-订阅模式的消息传输协议,适用于资源受限的设备和低带宽、高延迟或不稳定的网络环境。它在物联网应用中广受欢迎,能够实现传感器、执行器和其它设备…...