在 .NET Core 中需借助 Microsoft.Extensions.Configuration.Xml 包支持 XML 配置绑定,通过 AddXmlFile 加载 appsettings.xml,再用 IOptions 绑定到强类型类,注意键名格式、UTF-8 编码及不支持属性嵌套等限制。
在 .NET Core 中,可以使用内置的配置系统将 XML 配置文件绑定到强类型对象,但需要额外处理——因为 默认配置提供程序只原生支持 JSON、INI 和内存配置,不直接支持 XML。要绑定 XML,需借助第三方库(如 Microsoft.Extensions.Configuration.Xml)或手动解析后注入配置源。
安装 NuGet 包:
Microsoft.Extensions.Configuration.Xml该包提供了 XmlConfigurationProvider,让 IConfigurationBuilder 能加载 XML 文件。
例如:
注意:XML 键名需符合配置系统的层级规则(用冒号分隔),不能有重复 key; 是标准格式,会被自动映射为扁平键路径。
以 .NET 6+ 的最小托管模型为例:
builder.Configuration.AddXmlFile("appsettings.xml", optional: true, reloadOnChange: true)
AppSettings),含嵌套类 Features
builder.Services.Configure(builder.Configuration) 注册选项IOptions 或 IOptionsSnapshot 获取实例示例类:
public class AppSettings
{
public string AppName { get; set; } = string.Empty;
public string Version { get; set; } = string.Empty;
public Features Features { get; set; } = new();
}
public class Features
{
public bool EnableLogging { get; set; }
public int MaxRetries { get; set; }
}
),必须用 形式System.Xml.Serialization 手动反序列化再转为配置源AppName ↔ AppName,不是 appname)基本上就这些。只要 XML 格式规整、键路径清晰,绑定过程和 JSON 几乎一样自然。