Leer en inglés

Compartir vía


Extensions.GetSchemaInfo Método

Definición

Obtiene el conjunto de información posterior a la validación del esquema (PSVI) de un nodo validado.

Sobrecargas

GetSchemaInfo(XAttribute)

Obtiene el conjunto de información posterior a la validación del esquema (PSVI) de un atributo validado.

GetSchemaInfo(XElement)

Obtiene el conjunto de información posterior a la validación del esquema (PSVI) de un elemento validado.

Comentarios

Después de validar un XDocumentobjeto , puede recuperar el conjunto de información posterior a la validación del esquema para un XElement objeto o XAttribute contenido en el documento.

Después de recuperar el IXmlSchemaInfo objeto , puede usar las SchemaAttribute propiedades o SchemaElement para obtener un tipo de validación parcial (XmlSchemaElement o XmlSchemaAttribute). Puede usar los tipos de validación parciales para validar un atributo o un subárbol.

GetSchemaInfo(XAttribute)

Source:
XNodeValidator.cs
Source:
XNodeValidator.cs
Source:
XNodeValidator.cs

Obtiene el conjunto de información posterior a la validación del esquema (PSVI) de un atributo validado.

C#
public static System.Xml.Schema.IXmlSchemaInfo? GetSchemaInfo(this System.Xml.Linq.XAttribute source);
C#
public static System.Xml.Schema.IXmlSchemaInfo GetSchemaInfo(this System.Xml.Linq.XAttribute source);

Parámetros

source
XAttribute

XAttribute que se ha validado anteriormente.

Devoluciones

IXmlSchemaInfo que contiene el conjunto de información posterior a la validación del esquema para XAttribute.

Comentarios

Puede usar el IXmlSchemaInfo devuelto por este método para determinar determinadas características de un atributo validado. Por ejemplo, puede determinar si el atributo procede de un valor de atributo predeterminado en un XSD.

La propiedad se usa SchemaAttribute para obtener un tipo de validación parcial (XmlSchemaAttribute). Puede usarlo para volver a validar un atributo sin validar un documento completo.

Para obtener un ejemplo de esta propiedad, vea Validate.

Se aplica a

.NET 10 otras versiones
Producto Versiones
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetSchemaInfo(XElement)

Source:
XNodeValidator.cs
Source:
XNodeValidator.cs
Source:
XNodeValidator.cs

Obtiene el conjunto de información posterior a la validación del esquema (PSVI) de un elemento validado.

C#
public static System.Xml.Schema.IXmlSchemaInfo? GetSchemaInfo(this System.Xml.Linq.XElement source);
C#
public static System.Xml.Schema.IXmlSchemaInfo GetSchemaInfo(this System.Xml.Linq.XElement source);

Parámetros

source
XElement

XElement que se ha validado anteriormente.

Devoluciones

IXmlSchemaInfo que contiene el conjunto de información posterior a la validación del esquema (PSVI) para XElement.

Ejemplos

En el ejemplo siguiente se rellena el árbol con un PSVI. Después de la validación, imprime todos los elementos y atributos del árbol que no son válidos según psvi.

C#
                static void DumpInvalidNodes(XElement el)  
{  
    if (el.GetSchemaInfo().Validity != XmlSchemaValidity.Valid)  
        Console.WriteLine("Invalid Element {0}",  
            el.AncestorsAndSelf()  
            .InDocumentOrder()  
            .Aggregate("", (s, i) => s + "/" + i.Name.ToString()));  
    foreach (XAttribute att in el.Attributes())  
        if (att.GetSchemaInfo().Validity != XmlSchemaValidity.Valid)  
            Console.WriteLine("Invalid Attribute {0}",  
                att  
                .Parent  
                .AncestorsAndSelf()  
                .InDocumentOrder()  
                .Aggregate("",  
                    (s, i) => s + "/" + i.Name.ToString()) + "/@" + att.Name.ToString()  
                );  
    foreach (XElement child in el.Elements())  
        DumpInvalidNodes(child);  
}  

static void Main(string[] args)  
{  
    string xsdMarkup =  
         @"<xsd:schema xmlns:xsd='http://www.w3.org/2001/XMLSchema'>  
   <xsd:simpleType name='GCType'>  
    <xsd:restriction base='xsd:token'>  
     <xsd:enumeration value='AAA'/>  
     <xsd:enumeration value='BBB'/>  
    </xsd:restriction>  
   </xsd:simpleType>  
   <xsd:element name='Root'>  
    <xsd:complexType>  
     <xsd:sequence>  
      <xsd:element name='Child1' minOccurs='1' maxOccurs='1'>  
       <xsd:complexType>  
        <xsd:sequence>  
         <xsd:element name='GrandChild1' type='GCType'/>  
         <xsd:element name='GrandChild2' type='GCType'/>  
         <xsd:element name='GrandChild3' type='GCType'/>  
        </xsd:sequence>  
       </xsd:complexType>  
      </xsd:element>  
     </xsd:sequence>  
    </xsd:complexType>  
   </xsd:element>  
  </xsd:schema>";  

    XmlSchemaSet schemas = new XmlSchemaSet();  
    schemas.Add("", XmlReader.Create(new StringReader(xsdMarkup)));  

    XDocument doc1 = new XDocument(  
        new XElement("Root",  
            new XElement("Child1",  
                new XElement("GrandChild1", "AAA"),  
                new XElement("GrandChild2", "ZZZ"),  
                new XElement("GrandChild3", "ZZZ")  
            )  
        )  
    );  

    Console.WriteLine("Validating doc1 ...");  
    bool errors = false;  
    doc1.Validate(schemas, (sender, e) =>  
    {  
        Console.WriteLine(e.Message);  
        errors = true;  
    }, true);  
    Console.WriteLine("doc1 {0}", errors ? "did not validate" : "validated");  
    DumpInvalidNodes(doc1.Root);  
}  

Este ejemplo produce el siguiente resultado:

Validating doc1 ...  
The 'GrandChild2' element is invalid - The value 'ZZZ' is invalid according to its datatype 'GCType' - The Enumeration constraint failed.  
The 'GrandChild3' element is invalid - The value 'ZZZ' is invalid according to its datatype 'GCType' - The Enumeration constraint failed.  
doc1 did not validate  
Invalid Element /Root  
Invalid Element /Root/Child1  
Invalid Element /Root/Child1/GrandChild2  
Invalid Element /Root/Child1/GrandChild3  

Comentarios

Puede usar el IXmlSchemaInfo devuelto por este método para determinar determinadas características de un elemento validado. Por ejemplo, puede determinar el tipo de esquema dinámico del elemento.

La propiedad se usa SchemaElement para obtener un tipo de validación parcial (XmlSchemaElement). Puede usarlo para volver a validar un subárbol con un elemento en su raíz sin validar un documento completo.

Para obtener un ejemplo de esta propiedad, vea Validate.

Se aplica a

.NET 10 otras versiones
Producto Versiones
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1