在C#中用XSD验证xml需三步:加载XSD到XmlSchemaSet并赋给XmlReaderSettings.Schemas;设置ValidationType.Schema并订阅ValidationEventHandler;用XmlReader.Create创建验证读取器,循环Read()完成全量验证。

在C#中用XSD验证XML文件,核心是使用 XmlSchemaSet 加载XSD,再通过 XmlReaderSettings 启用验证,并创建带验证功能的 XmlReader 来读取XML。只要XML内容不符合XSD定义的结构或数据类型,就会触发验证事件并报告错误。
准备XSD和XML文件
确保你有配套的XSD文件(如 data.xsd)和待验证的XML文件(如 data.xml)。XSD必须能正确描述XML的元素、属性、命名空间和数据类型。如果XML用了命名空间,XSD中对应 targetNamespace 必须匹配,且XML根节点要声明相同命名空间。
加载XSD并配置验证设置
用 XmlSchemaSet 加载XSD,再将其赋给 XmlReaderSettings.Schemas;同时把 ValidationType 设为 ValidationType.Schema,并订阅 ValidationEventHandler 捕获错误:
- 不设置
ValidationEventHandler时,验证失败会直接抛出XmlSchemaValidationException - 推荐用事件方式收集所有错误,而不是中断处理
- 若XSD引用了其他XSD(如
xs:include或xs:import),确保路径可访问,或用XmlSchemaSet.Add()显式加载全部
执行验证并获取结果
用 XmlReader.Create(String, XmlReaderSettings) 创建验证型读取器,然后调用 Read() 遍历整个XML——验证会在读取过程中自动发生:
- 验证通过:不会触发事件,程序正常结束
- 验证失败:
ValidationEventHandler中的回调被调用,参数ValidationEventArgs包含错误级别(Warning或Error)、消息和异常详情 - 注意:只调用一次
Read()不够,需循环读到XmlnodeType.EndDocument才完成全量验证
一个最小可用示例
以下代码片段可直接运行(假定文件在当前目录):
var settings = new XmlReaderSettings(); settings.Schemas.Add("", "data.xsd"); // 空字符串表示无目标命名空间 settings.ValidationType = ValidationType.Schema; settings.ValidationEventHandler += (s, e) => Console.WriteLine($"[{e.Severity}] {e.Message}"); using var reader = XmlReader.Create("data.xml", settings); while (reader.Read()) { } // 触发完整验证
如果XSD定义了命名空间,Add("", ...) 要换成 Add("http://my.ns", ...),且XML中对应 xmlns="http://my.ns"。
基本上就这些。关键不是“能不能”,而是XSD是否写对、命名空间是否对齐、事件是否接住——三者缺一不可。