XmlSchemaSet 是 .NET 中编译、验证和缓存 XSD 的核心类,支持多模式合并、依赖解析与线程安全复用;需手动添加所有 import/include 的 Schema 并调用 Compile(),配合 ValidationEventHandler 可调试错误。
XmlSchemaSet 是 .NET 中用于编译、验证和缓存 XML Schema(XSD)的核心类。它替代了已过时的 XmlSchemaCollection,支持多模式合并、重复定义检测、命名空间隔离,并能高效复用已编译的 Schema。
最常见场景是读取本地 .xsd 文件,编译成可验证的内部表示:
XmlSchemaSet 实例(可指定 XmlNameTable 优化性能)Add() 方法传入目标命名空间和文件路径(或 XmlReader)Compile() —— 此步真正解析语法、检查约束、构建验证模型示例:
var schemas = new XmlSchemaSet();
schemas.Add("http://example.com/order", "order.xsd"); // 命名空间必须匹配 targetNamespace
schemas.Compile(); // 编译失败会抛出 XmlSchemaException
XmlSchemaSet 自动处理 、 和 ,前提是所有被引用的 Schema 都已加入集合中:
targetNamespace,否则 import 无法解析Compile() 会递归解析全部依赖,发现循环引用或缺失文件时抛异常注意:不支持从 HTTP URL 自动下载远程 schemaLocation,需手动加载并 Add 所有依赖项。
编译后的 XmlSchemaSet 是线程安全的,可全局共享,避免重复编译开销:
XmlReaderSettings.Schemas 即可复用XmlSchemaSet 并替换旧实例,避免并发修改问题验证示例:
var settings = new XmlReaderSettings { Schemas = schemas }; settings.ValidationType = ValidationType.Schema; using var reader = XmlReader.Create("order.xml", settings); while (reader.Read()) { } // 触发验证
编译或验证失败时,默认只抛异常。可通过 ValidationEventHandler 捕获详细信息:
Add() 前或 Compile() 前设置 schemas.ValidationEventHandler
ValidationEventArgs 包含错误级别(Warning/ Error)、消息、源文件和行号示例:
schemas.ValidationEventHandler += (sender, e) =>
{
Console.WriteLine($"{e.Severity}: {e.Message} at {e.Exception?.LineNumber}");
};