当前位置: 首页 > 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}");
}

相关文章:

  • 2025年的营销趋势-矩阵IP
  • C 语言中实现依赖反转(Dependency Inversion Principle,DIP)
  • linux安装单节点Elasticsearch(es),安装可视化工具kibana
  • 汽车行业EDI教程——北美X12标准 需求分析及方案
  • 通过模仿学习实现机器人灵巧操作:综述(下)
  • 1.9软考系统架构设计师:优秀架构设计师 - 超简记忆要点、知识体系全解、考点深度解析、真题训练附答案及解析
  • springboot启动的端口如何终止
  • pyqt中以鼠标所在位置为锚点缩放图片
  • 初识Redis · 哨兵机制
  • Hbase集群管理与实践
  • lumen中使用JWT下getTTL令牌过期源码解析(AI)
  • 基于Docker的Flask项目部署完整指南
  • Bytebase 3.5.1 - 扩展了对数据库的连接参数支持
  • 纯HTMLCSS静态网站——元神
  • 操作指南:vLLM 部署开源大语言模型(LLM)
  • Kafka与Spark-Streaming:大数据处理的黄金搭档
  • [mysql]数据类型精讲
  • 【MySQL】MySQL索引与事务
  • STUN协议 与 TURN协议
  • 广州 3D 展厅开启企业展示新时代​
  • 公安部知识产权犯罪侦查局:侦破盗录传播春节档院线电影刑案25起
  • 厦门国贸去年营收约3544亿元,净利润同比减少67.3%
  • 特朗普激发加拿大爱国热情之下:大选提前投票人数创纪录,魁北克分离情绪被冲淡
  • 福建一改造项目1人高处坠亡且事故迟报41天,住建厅约谈相关责任单位
  • 广州远洋宾馆负一层配电房发生火情:明火已扑灭,无人员伤亡
  • 最高检:去年共受理审查逮捕侵犯知识产权犯罪13486人