Compartir a través de


Validación del esquema XML (XSD) con XmlSchemaSet

Los documentos XML se pueden validar contra un lenguaje de definición de esquemas XML (XSD) en un XmlSchemaSet.

Validar documentos XML

Los documentos XML se validan mediante el Create método de la XmlReader clase . Para validar un documento XML, construya un XmlReaderSettings objeto que contenga un esquema del lenguaje de definición de esquemas XML (XSD) con el que validar el documento XML.

Nota:

El System.Xml.Schema espacio de nombres contiene métodos de extensión que facilitan la validación de un árbol XML en un archivo XSD cuando se usa LINQ to XML (C#) y LINQ to XML (Visual Basic). Para obtener más información sobre cómo validar documentos XML con LINQ to XML, vea Cómo validar mediante XSD (LINQ to XML) (C#) y Cómo: Validar mediante XSD (LINQ to XML) (Visual Basic).

Se puede agregar un esquema individual o un conjunto de esquemas (como un XmlSchemaSet) a un XmlSchemaSet si se pasa uno como parámetro al Add método de XmlSchemaSet. Al validar un documento, el espacio de nombres de destino del documento debe coincidir con el espacio de nombres de destino del esquema en el conjunto de esquemas.

A continuación se muestra un documento XML de ejemplo.

<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>

A continuación se muestra el esquema que valida el documento XML de ejemplo.

<?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>

En el ejemplo de código siguiente, el esquema anterior se agrega a la Schemas propiedad del XmlReaderSettings objeto . El XmlReaderSettings objeto se pasa como parámetro al Create método del XmlReader objeto , que valida el documento XML anterior.

La ValidationType propiedad del XmlReaderSettings objeto se establece en Schema para aplicar la validación del documento XML mediante el Create método del XmlReader objeto . Se agrega un ValidationEventHandler al objeto XmlReaderSettings para controlar cualquier evento Warning o Error, generados por errores encontrados durante el proceso de validación del documento XML y el 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 también