C# での参照された XSD に対する XML の検証
指定されたスキーマの場所を持つ XML ファイルが読み込まれると、そのファイルは C# のスキーマに対して自動的に検証されることが期待されます。ただし、スキーマを手動で指定する必要があるようです。
スキーマを手動で指定せずに XML を検証するには、XmlReaderSettings
のインスタンスを作成し、作成時にそれを XmlReader
に渡す必要があります。これにより、設定で ValidationEventHandler
を購読して検証エラーを受信できるようになります。
これを実現するために変更されたコード例は次のとおりです。
<code class="language-csharp">using System.Xml; using System.Xml.Schema; using System.IO; public class ValidXSD { public static void Main() { // 初始化验证设置。 XmlReaderSettings settings = new XmlReaderSettings(); settings.ValidationType = ValidationType.Schema; settings.ValidationFlags |= XmlSchemaValidationFlags.ProcessInlineSchema; settings.ValidationFlags |= XmlSchemaValidationFlags.ProcessSchemaLocation; settings.ValidationFlags |= XmlSchemaValidationFlags.ReportValidationWarnings; // 订阅验证事件处理程序。 settings.ValidationEventHandler += new ValidationEventHandler(ValidationCallBack); // 使用指定的验证设置加载 XML 文件。 XmlDocument asset = new XmlDocument(); XmlReader reader = XmlReader.Create("XML_file_path.xml", settings); // 解析文件。 while (reader.Read()) ; } // 显示验证错误或警告。 private static void ValidationCallBack(object sender, ValidationEventArgs args) { if (args.Severity == XmlSeverityType.Warning) Console.WriteLine("\t警告:未找到匹配的架构。未进行验证。" + args.Message); else Console.WriteLine("\t验证错误: " + args.Message); } }</code>
XmlReaderSettings
を使用すると、スキーマを明示的に指定せずに、参照される XSD に対して XML ファイルを自動的に検証できます。
以上がC# で参照された XSD に対して XML を自動的に検証する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。