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

news2024/11/27 4:25:21

简述:在构建 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 => {
    // 在请求发送之前可以对请求进行配置,如添加请求头、修改请求参数等
    // 例如,可以在这里添加认证 token
    return 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) {
      // 设置加载状态为 true
      this.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 URL
      apiUrl: process.env.VUE_APP_API_URL, // 读取环境变量 VUE_APP_API_URL 的值
    };
  },
};
</script>


总结

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

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

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

相关文章

MacOS miniconda安装方法

打开macos “终端” 应用 执行命令 mkdir -p ~/miniconda3curl https://mirrors.tuna.tsinghua.edu.cn/anaconda/miniconda/Miniconda3-latest-MacOSX-arm64.sh -o ~/miniconda3/miniconda.shbash ~/miniconda3/miniconda.sh -b -u -p ~/miniconda3rm -rf ~/miniconda3/mini…

nuxt、vue树形图d3.js

直接上代码 //安装 npm i d3 --save<template><div class"d3"><div :id"id" class"d3-content"></div></div> </template> <script> import * as d3 from "d3";export default {props: {d…

MongoDB-社区版-本地安装

系统&#xff1a;win10 1. 下载server:Download MongoDB Community Server | MongoDB 我选的zip包 2. 下载shell&#xff1a;MongoDB Shell Download | MongoDB 我选的zip包 3. 启动server 4. 启动shell, 完成

【基础算法】UE中实现轮播

本期作者&#xff1a;尼克 易知微3D引擎技术负责人 当前N 总数M 从0到M-1 从1到M 感谢阅读&#xff0c;以上内容均由易知微3D引擎团队原创设计&#xff0c;以及易知微版权所有&#xff0c;转载请注明出处&#xff0c;违者必究&#xff0c;谢谢您的合作。申请转载授权后台回复【…

堆叠的作用

一、为什么要堆叠 传统的园区网络采用设备和链路冗余来保证高可靠性&#xff0c;但其链路利用率低、网络维护成本高&#xff0c;堆叠技术将多台交换机虚拟成一台交换机&#xff0c;达到简化网络部署和降低网络维护工作量的目的。 二、堆叠优势 1、提高可靠性 堆叠系统多台成…

【深度学习】图形模型基础(5):线性回归模型第二部分:单变量线性回归模型

1.引言 在统计学与机器学习的广阔领域中&#xff0c;线性回归作为一种基础而强大的预测技术&#xff0c;其核心在于通过输入变量&#xff08;或称预测器、自变量&#xff09;来估计输出变量&#xff08;响应变量、因变量&#xff09;的连续值。本章聚焦于线性回归的一个基本但…

数据洞察:从零到一的数据仓库与Navicat连接全攻略【实训Day04】[完结篇]

一、数据分析 1 实现数据仓库(在hadoop101上) 1) 创建jobdata数据库 # cd $HIVE_HOME # bin/hive hive>create database jobdata; hive>use jobdata; 2) 创建原始职位数据事实表ods_jobdata_orgin(在hadoop101上) create table ods_jobdata_origin( city string CO…

Python爬虫零基础实战,简洁实用!

1.爬虫简介 简单来讲&#xff0c;爬虫就是一个探测机器&#xff0c;它的基本操作就是模拟人的行为去各个网站溜达&#xff0c;点点按钮&#xff0c;查查数据&#xff0c;或者把看到的信息背回来。就像一只虫子在一幢楼里不知疲倦地爬来爬去。 你可以简单地想象&#xff1a;每个…

Stream的获取、中间方法、终结方法

1、获取Stream流 单列集合&#xff1a;foreach完整版 双列集合通过Ketset()、entryset() 数组的&#xff1a;通过Arrays Stream流的中间方法&#xff1a;链式编程&#xff0c;原stream流只能使用一次 filter&#xff1a; limit、skip&#xff1a; distinct(有自定义对象需要重写…

MYSQL 四、mysql进阶 6(索引的创建与设计原则)

一、索引的声明和使用 1.1 索引的分类 MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。 从 功能逻辑 上说&#xff0c;索引主要有 4 种&#xff0c;分别是普通索引、唯一索引、主键索引、全文索引。 按照 物理实现方式 &#xff0c;索引可…

计算机网络之令牌总线

上文内容&#xff1a;什么是以太网 1.令牌总线工作原理 在总线的基础上&#xff0c;通过在网络结点之间有序地传递令牌来分配各结点对共享型总线的访问权利&#xff0c;形成闭合的逻辑环路。 完全采用半双工的操作方式&#xff0c;只有获得令牌的结点才能发送信息&#xff…

【matlab 项目工期优化】基于NSGA2/3的项目工期多目标优化(时间-成本-质量-安全)

一 背景介绍 本文分享了一个通用的项目工期优化的案例&#xff0c;决策变量是每个子项目的工期&#xff0c;优化目标是项目的完成时间最小&#xff0c;项目的总成本现值最小&#xff0c;项目的总安全水平最高&#xff0c;项目的总质量水平最高。采用的算法是NSGA2和NSGA3算法。…

YOLOV++ 详解 | 网络结构、代码解析、YOLOV 论文阅读、初识 VID

前言 代码地址&#xff1a;https://github.com/YuHengsss/YOLOV 本文网络结构按 YOLOV SwinTiny 绘制&#xff0c;不同的模型主要差异在于 Backbone&#xff0c;VID 相关的部分基本相同。 Predict Input 代码基于 vid_demo。首先会读取视频中的所有帧&#xff08;只能用短视频…

kafka系列之消费后不提交offset情况的分析总结

概述 每当我们调用Kafka的poll()方法或者使用KafkaListener(其实底层也是poll()方法)时&#xff0c;它都会返回之前被写入Kafka的记录&#xff0c;即我们组中的消费者还没有读过的记录。 这意味着我们有一种方法可以跟踪该组消费者读取过的记录。 如前所述&#xff0c;Kafka的一…

自闭症儿童的治疗方法有哪些?

身为星贝育园自闭症儿童康复学校的资深教育者&#xff0c;我深知自闭症谱系障碍&#xff08;ASD&#xff09;儿童的教育与治疗需要一个全面、个性化的方案。在星贝育园&#xff0c;我们致力于为孩子们提供一个充满爱与理解的环境&#xff0c;采用多种科学验证的教育方法&#x…

【Linux】动态库的制作与使用

&#x1f490; &#x1f338; &#x1f337; &#x1f340; &#x1f339; &#x1f33b; &#x1f33a; &#x1f341; &#x1f343; &#x1f342; &#x1f33f; &#x1f344;&#x1f35d; &#x1f35b; &#x1f364; &#x1f4c3;个人主页 &#xff1a;阿然成长日记 …

asp.net公交司机管理系统-计算机毕业设计源码96696

摘 要 公交司机是公交运输系统中的重要组成部分&#xff0c;他们的管理和运营对于公交运输的正常运行和服务质量起着至关重要的作用。本文提出了一种基于C#&#xff08;asp.net&#xff09;的公交司机管理系统。该系统利用计算机技术和网络通信技术&#xff0c;实现了公交司机信…

Ollama:本地大模型运行指南_ollama运行本地模型

Ollama 简介 Ollama 是一个基于 Go 语言开发的可以本地运行大模型的开源框架。 官网&#xff1a;ollama.com/ GitHub 地址&#xff1a;github.com/ollama/olla… Ollama 安装 【一一AGI大模型学习 所有资源获取处一一】 ①人工智能/大模型学习路线 ②AI产品经理入门指南 ③…

【 香橙派 AIpro评测】大语言模型实战教程:香橙派 AIpro部署LLMS大模型实站(保姆级教学)

引言 OrangePi AIpro 这块板子作为业界首款基于昇腾深度研发的AI开发板&#xff0c;一经发布本博主就火速去关注了&#xff0c;其配备的 8/20TOPS澎湃算力是目前开发板市场中所具备的最大算力&#xff0c;可谓是让我非常眼馋啊&#xff01;这么好的板子那必须拿来用用&#xff…

Java面试八股之如何提高MySQL的insert性能

如何提高MySQL的insert性能 提高MySQL的INSERT性能可以通过多种策略实现&#xff0c;以下是一些常见的优化技巧&#xff1a; 批量插入&#xff1a; 而不是逐条插入&#xff0c;可以使用单个INSERT语句插入多行数据。例如&#xff1a; INSERT INTO table_name (col1, col2) V…