Compartilhar via


Validação do esquema XML (XSD) com XmlSchemaSet

Documentos XML podem ser validados contra uma linguagem de definição de esquema XML (XSD) em um XmlSchemaSet.

Validar documentos XML

Os documentos XML são validados pelo Create método da XmlReader classe. Para validar um documento XML, construa um XmlReaderSettings objeto que contenha um esquema XSD (linguagem de definição de esquema XML) com o qual validar o documento XML.

Observação

O System.Xml.Schema namespace contém métodos de extensão que facilitam a validação de uma árvore XML em um arquivo XSD ao usar LINQ to XML (C#) e LINQ to XML (Visual Basic). Para obter mais informações sobre como validar documentos XML com LINQ to XML, consulte Como validar usando XSD (LINQ to XML) (C#) e Como validar o uso de XSD (LINQ to XML) (Visual Basic).

Um esquema individual ou um conjunto de esquemas (como um XmlSchemaSet) pode ser adicionado a um XmlSchemaSet passando um deles como um parâmetro para o Add método de XmlSchemaSet. Ao validar um documento, o namespace de destino do documento deve corresponder ao namespace de destino do esquema no conjunto de esquemas.

Veja a seguir um documento XML de exemplo.

<bookstore xmlns="http://www.contoso.com/books">
  <book genre="autobiography" publicationdate="1981-03-22" ISBN="1-861003-11-0">
    <title>The Autobiography of Benjamin Franklin</title>
    <author>
      <first-name>Benjamin</first-name>
      <last-name>Franklin</last-name>
    </author>
    <price>8.99</price>
  </book>
  <book genre="novel" publicationdate="1967-11-17" ISBN="0-201-63361-2">
    <title>The Confidence Man</title>
    <author>
      <first-name>Herman</first-name>
      <last-name>Melville</last-name>
    </author>
    <price>11.99</price>
  </book>
  <book genre="philosophy" publicationdate="1991-02-15" ISBN="1-861001-57-6">
    <title>The Gorgias</title>
    <author>
      <name>Plato</name>
    </author>
    <price>9.99</price>
  </book>
</bookstore>

Veja a seguir o esquema que valida o documento XML de exemplo.

<?xml version="1.0" encoding="utf-8"?>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" targetNamespace="http://www.contoso.com/books" xmlns:xs="http://www.w3.org/2001/XMLSchema">
    <xs:element name="bookstore">
        <xs:complexType>
            <xs:sequence>
                <xs:element maxOccurs="unbounded" name="book">
                    <xs:complexType>
                        <xs:sequence>
                            <xs:element name="title" type="xs:string" />
                            <xs:element name="author">
                                <xs:complexType>
                                    <xs:sequence>
                                        <xs:element minOccurs="0" name="name" type="xs:string" />
                                        <xs:element minOccurs="0" name="first-name" type="xs:string" />
                                        <xs:element minOccurs="0" name="last-name" type="xs:string" />
                                    </xs:sequence>
                                </xs:complexType>
                            </xs:element>
                            <xs:element name="price" type="xs:decimal" />
                        </xs:sequence>
                        <xs:attribute name="genre" type="xs:string" use="required" />
                        <xs:attribute name="publicationdate" type="xs:date" use="required" />
                        <xs:attribute name="ISBN" type="xs:string" use="required" />
                    </xs:complexType>
                </xs:element>
            </xs:sequence>
        </xs:complexType>
    </xs:element>
</xs:schema>

No exemplo de código a seguir, o esquema acima é adicionado à Schemas propriedade do XmlReaderSettings objeto. O objeto XmlReaderSettings é passado como um parâmetro para o método Create do objeto XmlReader, que valida o documento XML acima.

A propriedade do objeto ValidationType é definida como XmlReaderSettings para forçar a validação do documento XML pelo método Schema do objeto Create. Um ValidationEventHandler é adicionado ao XmlReaderSettings objeto para manipular qualquer Warning ou Error eventos gerados por erros encontrados durante o processo de validação do documento XML e do esquema.

using System;
using System.Xml;
using System.Xml.Schema;

class XmlSchemaSetExample
{
    static void Main()
    {
        XmlReaderSettings booksSettings = new XmlReaderSettings();
        booksSettings.Schemas.Add("http://www.contoso.com/books", "books.xsd");
        booksSettings.ValidationType = ValidationType.Schema;
        booksSettings.ValidationEventHandler += booksSettingsValidationEventHandler;

        XmlReader books = XmlReader.Create("books.xml", booksSettings);

        while (books.Read()) { }
    }

    static void booksSettingsValidationEventHandler(object sender, ValidationEventArgs e)
    {
        if (e.Severity == XmlSeverityType.Warning)
        {
            Console.Write("WARNING: ");
            Console.WriteLine(e.Message);
        }
        else if (e.Severity == XmlSeverityType.Error)
        {
            Console.Write("ERROR: ");
            Console.WriteLine(e.Message);
        }
    }
}
Imports System.Xml
Imports System.Xml.Schema

Class XmlSchemaSetExample

    Shared Sub Main()

        Dim booksSettings As XmlReaderSettings = New XmlReaderSettings()
        booksSettings.Schemas.Add("http://www.contoso.com/books", "books.xsd")
        booksSettings.ValidationType = ValidationType.Schema
        AddHandler booksSettings.ValidationEventHandler, New ValidationEventHandler(AddressOf booksSettingsValidationEventHandler)

        Dim books As XmlReader = XmlReader.Create("books.xml", booksSettings)

        While books.Read()

        End While

    End Sub

    Shared Sub booksSettingsValidationEventHandler(ByVal sender As Object, ByVal e As ValidationEventArgs)

        If e.Severity = XmlSeverityType.Warning Then
            Console.Write("WARNING: ")
            Console.WriteLine(e.Message)

        ElseIf e.Severity = XmlSeverityType.Error Then
            Console.Write("ERROR: ")
            Console.WriteLine(e.Message)
        End If

    End Sub

End Class

Consulte também