一个简单又好用的.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#接口调用+局域网访问!全攻略来了!

相关推荐
程序员码歌1 小时前
【零代码AI编程实战】AI灯塔导航-总结篇
android·前端·后端
java坤坤1 小时前
GoLand 项目从 0 到 1:第八天 ——GORM 命名策略陷阱与 Go 项目启动慢问题攻坚
开发语言·后端·golang
元清加油2 小时前
【Golang】:函数和包
服务器·开发语言·网络·后端·网络协议·golang
bobz9652 小时前
GPT-4.1 对比 GPT-4o
后端
Java小白程序员3 小时前
Spring Framework :IoC 容器的原理与实践
java·后端·spring
小小愿望3 小时前
前端无法获取响应头(如 Content-Disposition)的原因与解决方案
前端·后端
追逐时光者4 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 50 期(2025年8.11-8.17)
后端·.net
杨DaB4 小时前
【SpringBoot】Swagger 接口工具
java·spring boot·后端·restful·swagger
why技术4 小时前
也是震惊到我了!家里有密码锁的注意了,这真不是 BUG,是 feature。
后端·面试
桦说编程5 小时前
方法一定要有返回值 \ o /
java·后端·函数式编程