【.Net8教程】(一)读取配置文件全面总结

环境:.net8.0

1. 准备条件

先在appsettings.Development.json或appsettings.json添加配置

添加一个DbOption

json 复制代码
{
  "DbOption": {
    "Conn": "foolishsunday@csdn"
  }
}

2.直接读取json配置节点的几种写法

在Main函数中读取json配置

方式一

csharp 复制代码
var conn1 = builder.Configuration["DbOption:Conn"];

方式二

csharp 复制代码
var conn2 = builder.Configuration.GetValue<string>("DbOption:Conn");

方式三

csharp 复制代码
var conn3 = builder.Configuration.GetSection("DbOption").GetSection("Conn").Value;

方式四

csharp 复制代码
var conn4 = builder.Configuration.GetSection("DbOption")["Conn"];

3.转化为类或record类型

定义类

csharp 复制代码
    public class DbOption
    {
        public string Conn { get; set; }
    }

转化

csharp 复制代码
DbOption opt = builder.Configuration.GetSection(nameof(DbOption)).Get<DbOption>();

4.通过注入IConfiguration方式

csharp 复制代码
    [ApiController]
    [Route("[controller]")]
    public class TestController : ControllerBase
    {
        private readonly IConfiguration _configuration;

        public TestController(IConfiguration configuration)
        {
            _configuration = configuration;
        }
        [HttpPost]
        public async Task<IActionResult> GetConfig()
        {
            var conn1 = _configuration["DbOption:Conn"];
            var conn2 = _configuration.GetValue<string>("DbOption:Conn");
            var conn3 = _configuration.GetSection(nameof(DbOption)).GetSection("Conn").Value;
            return Ok();
        }   
    }

5.或通过Options模式(推荐)

写法一

csharp 复制代码
builder.Services.Configure<DbOption>(builder.Configuration.GetSection(nameof(DbOption)));

写法二

csharp 复制代码
builder.Services.AddOptions<DbOption>().Bind(builder.Configuration.GetSection(nameof(DbOption)));

写法三

csharp 复制代码
builder.Services.AddOptions<DbOption>().BindConfiguration(nameof(DbOption));

然后通过注入IOptions、IOptionsMonitor或IOptionsSnapshot获取

csharp 复制代码
    [ApiController]
    [Route("[controller]")]
    public class DemoController : ControllerBase
    {
        private readonly DbOption _dbOption;

        public DemoController(IOptionsSnapshot<DbOption> dbOption)
        {
            _dbOption = dbOption.Value;//注意此处为.Value
        }   
    }

推荐使用IOptionsSnapshot

Options模式有三个接口IOptions、IOptionsMonitor或IOptionsSnapshot

IOption :单例,一旦生成就不会再更改,除非通过代码的方式更改;

OptionsMonitor :也是单例,但是它只要配置有变更,它就会更新,能通过代码的方式更改值;

IOptionsSnapshot :作用域注册,一次请求里值不会变,在配置文件更新的下一次请求,它的值会更新,但是它不能跨范围通过代码的方式更改值,只能在当前范围(请求)内有效

校验

其中写法二与写法三,如果忘记了配置,获取到值为null,是不会报错的。

如果需要在获取到null时报错,则可以添加Validate校(可抛OptionsValidationException异常)

csharp 复制代码
builder.Services.AddOptions<DbOption>().BindConfiguration(nameof(DbOption))
.Validate(option =>
{
    if (string.IsNullOrEmpty(option.Conn)) return false;
    else return true;
});

6. 注意:调试和发布后启动,读取配置文件的区别

1、当启动vs调试时,由于启动的环境是Development,所以读取配置文件会优先读取appsettings.Development.json;如果没有值,才读取appsettings.json的值;

2、但当我们发布程序启动后(如双击.exe启动),则读取的是appsettings.json文件。

此区别可能会造成初学者产生混淆。

相关推荐
步步为营DotNet1 天前
深入理解IAsyncEnumerable:.NET中的异步迭代利器
服务器·前端·.net
玩泥巴的1 天前
强的飞起的 Roslyn 编译时代码生成,实现抽象类继承与依赖注入的自动化配置
c#·.net·代码生成·roslyn
mudtools1 天前
强的飞起的 Roslyn 编译时代码生成,实现抽象类继承与依赖注入的自动化配置
c#·.net
马达加斯加D1 天前
Web框架 --- .Net中的Worker Service
.net
步步为营DotNet1 天前
深入解读CancellationToken:.NET异步操作的精准控制
java·前端·.net
运维小文1 天前
Centos7部署.net8和升级libstdc++
开发语言·c++·.net
步步为营DotNet1 天前
深度探究.NET中的IAsyncEnumerable:异步迭代的底层奥秘与高效实践
.net
唐青枫1 天前
C# 泛型数学:解锁真正的类型安全数值运算
c#·.net
追逐时光者1 天前
C#/.NET/.NET Core技术前沿周刊 | 第 63 期(2025年11.24-11.30)
后端·.net