当前位置: 首页 > news >正文

ASP.NET Core 自动识别 appsettings.json的机制解析

ASP.NET Core 自动识别 appsettings.json 的机制解析

在 ASP.NET Core 中,IConfiguration 能自动识别 appsettings.json 并直接读取值的机制,是通过框架的 “约定优于配置” 设计和 依赖注入系统 共同实现的。以下是详细原理:


  1. 默认配置源的自动注册
    当使用 WebApplication.CreateBuilder() 创建应用时,框架会 自动加载默认配置源:
var builder = WebApplication.CreateBuilder(args);
// 等价于:
var builder = WebApplication.CreateBuilder(new WebApplicationOptions {Args = args,// 默认加载以下配置源(按优先级从高到低):// 1. 命令行参数// 2. 环境变量(前缀为 DOTNET_ 或 ASPNETCORE_)// 3. appsettings.{Environment}.json// 4. appsettings.json// 5. 用户机密(开发环境)
});

  1. 配置系统的初始化流程

  2. 自动查找配置文件
    • 框架会在程序集所在目录查找以下文件:

    appsettings.json(基础配置)

    appsettings.{Environment}.json(环境特定配置,如 appsettings.Development.json

  3. 自动加载到 IConfiguration
    • 通过 ConfigurationManager 自动合并所有配置源:

    builder.Configuration.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true);
    builder.Configuration.AddJsonFile($"appsettings.{builder.Environment.EnvironmentName}.json", optional: true);
    
  4. 注入到依赖系统
    builder.Build() 时会将 ConfigurationManager 实例注册为 IConfiguration 服务:

    services.AddSingleton<IConfiguration>(builder.Configuration);
    

  1. 直接访问配置值的原理
    通过 _configuration["MyKey"] 获取值时,实际调用链如下:
_configuration ConfigurationManager ConfigurationProvider 请求键"MyKey" 按优先级遍历所有Provider 返回匹配的值 返回最终值 _configuration ConfigurationManager ConfigurationProvider
  1. 键名匹配规则
    • 支持多级配置(用冒号分隔):

    {"Section": {"SubSection": {"MyKey": "Value"}}
    }
    
    {
    "Section2": {"Section3": {"SubSection": {"MyKey": "Value"}}}
    }
    
    _configuration["Section:SubSection:MyKey"]; // 返回 "Value"
    _configuration["Section3:Section2:SubSection:MyKey"];
    
  2. 值转换
    • 自动将字符串值转换为其他类型(通过 Get<T> 方法):

    int timeout = _configuration.GetValue<int>("Timeout");
    

  1. 动态加载与更新
    • 文件监控:

默认启用 reloadOnChange: true,修改文件后会自动重新加载配置。

// 监听文件变化
builder.Configuration.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true);

• 环境切换:

ASPNETCORE_ENVIRONMENT 环境变量改变时,会自动加载对应的环境配置文件。


  1. 为什么不需要手动注册?
    • 隐式服务注册:

WebApplication.CreateBuilder 已包含默认服务配置(ConfigureHostDefaultsConfigureAppDefaults)。

• 约定优先:

框架默认认为 appsettings.json 是标准配置文件,除非显式禁用。


  1. 自定义配置加载
    如果需要完全控制配置加载,可以手动初始化:
var config = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("custom.json") // 自定义文件.AddEnvironmentVariables().Build();var builder = WebApplication.CreateBuilder(new WebApplicationOptions {Configuration = config // 替换默认配置
});

  1. 验证配置是否加载
// 打印所有配置键值
foreach (var kv in _configuration.AsEnumerable())
{Console.WriteLine($"{kv.Key}: {kv.Value}");
}

http://www.xdnf.cn/news/141661.html

相关文章:

  • 网络准入控制系统:2025年网络安全的坚固防线
  • 解析excel中的图片
  • 深入解析YOLO v1:实时目标检测的开山之作
  • 观测云数据在Grafana展示的最佳实践
  • 【安全扫描器原理】TCP/IP协议编程
  • 在 Vue3 中封装的 Axios 实例中,若需要为部分接口提供手动取消请求的功能
  • 智慧医疗领域TMI期刊2025年3月研究热点解析
  • 【音视频】AVIO输入模式
  • 红队系列-网络安全知识锦囊-CTF(持续更新)
  • Mac「brew」快速安装Redis
  • 猫咪如厕检测与分类识别系统系列【十三】猫咪进出事件逻辑及日志优化【下】
  • 第六章 进阶06 读书群第一次团建
  • Kubernetes in action-初相识
  • 从StandardMaterial和PBRMaterial到PBRMetallicRoughnessMaterial:Babylon.js材质转换完全指南
  • linux 部署express项目,并使用pm2守护进程
  • yum包管理器
  • systemctl 命令详解与常见问题解决
  • .NET中,const和readonly区别
  • NLP高频面试题(五十五)——DeepSeek系列概览与发展背景
  • 自动清空 maven 项目临时文件,vue 的 node_modules 文件
  • Virtuoso ADE采用Spectre仿真中出现MOS管最小长宽比满足要求依然报错的情况解决方法
  • 【高频考点精讲】async/await原理剖析:Generator和Promise的完美结合
  • RTMP 入门指南
  • Aloudata Agent :基于 NoETL 明细语义层的分析决策智能体
  • Linux阻塞与非阻塞I/O:从原理到实践详解
  • 学硕热度下降,25西电数学与统计学院(考研录取情况)
  • 高频面试题:如何保证数据库和es数据一致性
  • ES历史版本下载
  • 第TR5周:Transformer实战:文本分类
  • 图像识别系统 - Ubuntu部署指南(香橙派开发板测试)-学习记录1