前端打包注入process.env

在前端开发过程中,有时候需要用到本地配置,比如一些api的key或者对于每个开发者私有的配置(开发者本地ip等)。这些配置信息不能直接放到git仓库中去,一方面是会暴露隐私信息,另一方面会干扰到其他开发的使用。

本文叙述了如何将本地配置文件注入到前端项目中去的方法和步骤:

首先需要使用dotenv第三方库使本地配置在node环境下可用,[关于dotenv的使用可见我的另一篇文章](使用dotenv库的基本步骤 - 掘金 (juejin.cn))

然后就是如何让这些配置在浏览器中也生效,这里分两种情况讨论:

1. 不使用框架

如果前端项目是开发自己使用webpack搭建的,那么只需要在webpack中进行一些额外的配置就可以直接在浏览器环境中使用process这个对象了,具体来说就是使用名为webpack.DefinePlugin的插件,额外的配置代码如下:

js 复制代码
const webpack = require('webpack');

module.exports = {
  // ... 其他配置
  plugins: [
    // 定义环境变量
    new webpack.DefinePlugin({
      'process.env': JSON.stringify(process.env),
    }),
  ],
  // ... 其他配置
};

2. 使用前端框架

这里以RCA为例。RCA已经做了相关的处理,只需要保证将要注入到浏览器中的本地配置信息字段名以REACT_APP开头即可!

env 复制代码
REACT_APP_OPENAI_KEY=sk-7HFYCtmUItc9Y2MG8642E896C61a42Aa87D3Cc7a***********

在打包的时候CRA框架就会自动将代码中的process.env.REACT_APP_OPENAI_KEY替换成对应的值!也就是说在代码中可以直接使用process.env.REACT_APP_OPENAI_KEY取到对应的值。

!!注意这并不意味window.process.env.REACT_APP_OPENAI_KEY是存在的,这是打包的时候被替换了而已!!

相关推荐
森叶几秒前
Electron 实战:用 utilityProcess 开子进程,去端口化承载协议处理,并由主进程拦截渲染请求后统一中转
前端·javascript·electron
精益数智工坊6 分钟前
红牌作战是什么?红牌作战的实施步骤与核心要点
大数据·运维·前端·人工智能·精益工程
techdashen12 分钟前
Cloudflare HTML 解析器的十年演化史(一)
前端·html
ZC跨境爬虫20 分钟前
移动端爬虫工具Fiddler完整配置流程:PC+安卓模拟器全覆盖,零基础一次配置成功
android·前端·爬虫·测试工具·fiddler
GISer_Jing25 分钟前
前端视角:B端传统配置化现状与AI冲击趋势
前端·人工智能·ai编程
课灵_klhubs29 分钟前
课灵h5p-3D 模型 (3D Model)教程
前端·3d·课程设计·教程·课灵·h5p
倾颜38 分钟前
接入 MCP 之后,我如何让 Skill 稳定消费 Tool / Resource / Prompt
前端·next.js·mcp
小赵同学WoW38 分钟前
BroadCast Channel() 浏览器跨标签页通信的实现方式之一
前端·浏览器
\xin39 分钟前
pikachu自编exp,xss之盲打,过滤,htmlspecialchars,href,js
前端·xss
ZC跨境爬虫1 小时前
前端实战复盘:从零完成Apple中国大陆官网UI第一阶段全量静态复刻
前端·css·ui·html