一个简单又好用的.Net版本.env文件读写操作库

推荐一个开源库,方便我们从 .env 文件加载环境变量,简化应用程序配置管理。

01 项目简介

dotenv.net是一个职场 .NET Core 环境中读取 .env 文件的库。它可以轻松地加载环境变量到应用程序的配置中,从而实现不同环境下的配置管理。

  • 简单且无痛🎯:.env只需最少的设置即可轻松加载和读取文件。

  • 灵活的配置🔧:使用各种选项自定义环境变量的加载方式。

  • 依赖注入支持🧩:与流行的 DI 框架无缝协作。

  • 跨平台🌍:与.NET Core、.NET 5 及更高版本完全兼容。

02 快速入门

1、安装

使用 .NET CLI

csharp 复制代码
dotnet add package dotenv.net

使用 Visual Studio 包管理器

复制代码
Install-Package dotenv.net

2、简单使用方法

ini 复制代码
using dotenv.net;
DotEnv.Load();
var envVars = DotEnv.Read();
Console.WriteLine(envVars["KEY"]);

其中Load()的时候,会从而应用程序的目录读取.env文件。

3、自定义.env文件路径

php 复制代码
DotEnv.Load(options: new DotEnvOptions(envFilePaths: new[] {"./path/to/env", "./path/to/second/env"}));

4、启用异常处理

php 复制代码
DotEnv.Load(options: new DotEnvOptions(ignoreExceptions: false));

5、在父目录中搜索.env文件

php 复制代码
DotEnv.Load(options: new DotEnvOptions(probeForEnv: true, probeLevelsToSearch: 2));

6、去掉值的空白字符

php 复制代码
DotEnv.Load(options: new DotEnvOptions(trimValues: true));

7、多次加载,是否不覆盖现有环境变量

php 复制代码
DotEnv.Load(options: new DotEnvOptions(overwriteExistingVars: false));

8、提供一个流畅的 API,更简洁直观的语法

scss 复制代码
// 加载环境变量
DotEnv.Fluent()
    .WithExceptions()
    .WithEnvFiles("./path/to/env")
    .WithTrimValues()
    .WithEncoding(Encoding.ASCII)
    .WithOverwriteExistingVars()
    .WithProbeForEnv(probeLevelsToSearch: 6)
    .Load();

// 读取环境变量
var envVars = DotEnv.Fluent()
    .WithoutExceptions()
    .WithEnvFiles() //默认为 .env
    .WithoutTrimValues()
    .WithDefaultEncoding()
    .WithoutOverwriteExistingVars()
    .WithoutProbeForEnv()
    .Read();

9、另外提供 Utilities 命名空间,以类型化方式读取环境变量的额外方法:

ini 复制代码
using dotenv.net.Utilities;

var stringValue = EnvReader.GetStringValue("KEY");
var intValue = EnvReader.GetIntValue("PORT");
var boolValue = EnvReader.GetBooleanValue("ENABLE_FEATURE");

更多的方法如下:

03 项目地址

github.com/bolorunduro...

  • End -

推荐阅读

2个零基础入门框架教程!

SmartFormat:轻量级文本模板库,轻松替代 string.Format

Squidex:一个基于.Net功能强大的CMS开源项目

barcodelib:一个功能强大且易于使用的 C# 条形码生成库

一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略来了!

相关推荐
易安说AI1 小时前
Codex 直接住进 JetBrains IDE 里:AI Agent 正在接管熟悉的开发入口
后端
子兮曰2 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
Wy_编程3 小时前
go语言中的结构体
开发语言·后端·golang
独自归家的兔5 小时前
OCPP 1.6 协议详解:GetLocalListVersion 获取本地列表版本指令
java·后端·物联网·spring·ocpp1.6
无人不xiao7 小时前
springBoot 实现 接口进度条
java·spring boot·后端
IT_陈寒7 小时前
Redis缓存击穿把我坑惨了,原来这样解决才靠谱
前端·人工智能·后端
Lee川8 小时前
RAG 知识库问答:从概念到代码的完整实现
前端·人工智能·后端
咪的Coding8 小时前
为什么在 DeepSeek 输入 <think>,它竟吐出别人的“记忆碎片”!?
后端·deepseek
HLAIA光子8 小时前
这些Spring Boot写法已经过时了!
spring boot·后端