.NET Core 通过 Microsoft.Extensions.Configuration.Xml 包支持 XML 配置文件,如 appsettings.xml,其 key 属性支持冒号分隔的层级路径(如 Logging:LogLevel:Default),自动映射为 IConfiguration 树结构;自定义 XML 结构需手动解析后通过 AddInMemoryCollection 注入;配合 IOptions 使用方式与 JSON 完全一致。
.NET Core 本身不直接支持将 XML 文件作为主配置源(像 appsettings.json 那样开箱即用),但可以通过自定义 ConfigurationProvider 或借助第三方库(如 Serilog.Settings.XML)来读取 XML 配置。不过,最常用、最推荐的方式是:把 XML 配置转换为标准的 IConfiguration 树结构,再集成进 .NET Core 的配置系统。
.NET Core 官方提供了 Microsoft.Extensions.Configuration.Xml 包,专门用于加载 XML 配置文件(如 appsettings.xml)。它支持层级映射,语法类似 JSON,但用 XML 标签表示。
Microsoft.Extensions.Configuration.Xml

注意:key 属性支持冒号分隔的层级路径(如 Logging:LogLevel:Default),会被自动解析为 IConfiguration 的嵌套节点。
Program.cs 中加载:如果你的 XML 是自定义结构(比如带命名空间、复杂嵌套、属性+文本混合),官方 XmlConfigurationProvider 就不适用了。这时可手动解析 XML,再注入到 IConfiguration 中:
XDocument 或 XmlSerializer 解析 XML 内容configuration.AddInMemoryCollection(dict)
例如,XML 中有 Database:Host → 值 localhost。
只要 XML 被成功加载进 IConfiguration,后续使用 IOptions
builder.Services.Configure(builder.Configuration.GetSection("MySection"));
IOptions 即可XML 加载不生效?检查这几项:
Logging:Level ≠ Logging.Level)基本上就这些。不复杂但容易忽略细节 —— 关键是让 XML 的 key 结构匹配 IConfiguration 的层级约定。