如何对环境变量增加智能提示与校验

当我们开发或者部署时,往往需要将环境变量配置到 .env 文件当中。

如果你是多人协作项目,应该遇到过这种情况:

  1. 你在开发某个功能,你将所需要的环境变量写入到.env中。
  2. 然而.env文件很重要,你不能将其暴露给代码托管平台。
  3. 你提交了代码,并且将私密的环境变量写入 Vercel 或者 K8S 等地方。
  4. 线上代码运行良好,你很满意,并且在项目文档中加了一条:添加 XXX 变量。
  5. 第二天,你的懒汉同事们发现本地代码(或功能)运行不起来。经过半个小时的功能测试,最后发现仅仅是环境变量没有配齐。

又或者遇到过这种情况:

你使用 Typescript,你很享受 Typescript 的类型提示带来的便利。

然而,当你输入 process.env时,并没有出现你想要的类型提示。

于是,身为懒汉的你只能从庞大的项目目录中再次翻找出 env 文件,打开-拷贝-粘贴...

为了解决上面两个懒汉问题,我们可以使用一个支持 Typescript 类型的验证库:

复制代码
pnpm install zod 

假设我们的.env文件中有一个环境变量:

ini 复制代码
EMAIL_FROM=xxx@gmail.com

新建一个 env.ts文件,写入:

vbnet 复制代码
import { z } from 'zod'
​
const environmentSchema = z.object({
  EMAIL_FROM: z.string().email(),
})
​
try {
  environmentSchema.parse(process.env)
} catch (error) {
  console.log('孙子,你的环境变量出错啦')
  console.log(error)
}

现在你已经完成了环境变量的校验,请将 env.ts 文件引入到项目的启动文件,以让项目的编译工具打包而不是被 tree shaking 掉。

以 nextjs 为例,将其引入到layout.tsx文件中,这样 env.ts文件就会随着项目的启动而被编译。

arduino 复制代码
// layout.tsx
import '../env'

现在如果你的环境变量不满足 email 的条件,那么你的控制台一定会报错:

现在你已经完成了对process.env 进行了验证。

等下次你的懒汉同事启动项目时,一定会发现他多了一个爷爷。

接着,是让同样为懒汉的你省去没有智能提示的烦恼。

我们利用 zod 提供的类型推导功能,将类型提取出来:

ini 复制代码
type EnvVarSchemaType = z.infer<typeof environmentSchema>

最后,我们覆盖掉默认的 process.env 的类型

typescript 复制代码
declare global {
  namespace NodeJS {
    interface ProcessEnv extends EnvVarSchemaType {}
  }
}

测试一下看看:

本文的分享到此结束。

相关推荐
ZC跨境爬虫1 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦1 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
卷毛的技术笔记1 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
喵个咪1 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
会编程的土豆2 小时前
Go 语言反射(Reflection)详解
开发语言·后端·golang
喵个咪2 小时前
GoWind Toolkit Go后端代码生成 完整全流程实战
后端·go·orm
basketball6162 小时前
Go 语言从入门到进阶:4. 数组和MAP使用方法总结
开发语言·后端·golang
qq_2518364572 小时前
SpringBoot+Vue 共享电池柜管理系统 完整实现 前后端分离项目实战 完整代码
vue.js·spring boot·后端
摆烂大大王3 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao3 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端