Cómo completar los nombres de elementos y atributos XML

Ejemplo de código

Los espacios de nombres XML incluidos en instancias de la clase XmlSerializerNamespaces deben ajustarse a la especificación del W3C (World Wide Web Consortium), en www.w3.org, denominada "Namespaces in XML".

Los espacios de nombres XML proporcionan un método para completar los nombres de elementos y atributos XML en documentos XML. Un nombre completo se compone de un prefijo y un nombre local, separados por dos puntos. El prefijo funciona únicamente como marcador de posición y está asignado a un URI que especifica un espacio de nombres. La combinación del espacio de nombres del URI administrado universalmente y el nombre local genera un nombre del que se garantiza que es universalmente único.

Al crear una instancia de XmlSerializerNamespaces y agregar pares de espacios de nombres al objeto, puede especificar los prefijos utilizados en un documento XML.

Para crear nombres completos en un documento XML

  1. Cree una instancia de la clase XmlSerializerNamespaces.

  2. Agregue todos los pares de espacios de nombres y prefijos a la instancia de XmlSerializerNamespaces.

  3. Aplique el atributo System.Xml.Serialization apropiado a cada miembro o clase que XmlSerializer serializará en un documento XML.

    Los atributos disponibles son: XmlAnyElementAttribute, XmlArrayAttribute, XmlArrayItemAttribute, XmlAttributeAttribute, XmlElementAttribute, XmlRootAttribute y XmlTypeAttribute.

  4. Establezca el valor de la propiedad Namespace de cada atributo en uno de los valores del espacio de nombres de XmlSerializerNamespaces.

  5. Pase XmlSerializerNamespaces al método Serialize de XmlSerializer.

Ejemplo

En el ejemplo siguiente se crea un objeto XmlSerializerNamespaces al que se agregan dos pares de prefijos y espacios de nombres. El código crea un XmlSerializer que se utiliza para serializar una instancia de la clase Books. En el código se llama al método Serialize con XmlSerializerNamespaces, lo que permite que el XML contenga espacios de nombres con prefijo.

Option Explicit 
public class Price
{
    [XmlAttribute(Namespace = "http://www.cpandl.com")]
    public string currency;
    [XmlElement(Namespace = "http://www.cohowinery.com")]
    public decimal price;
}

Option Strict

Imports System
Imports System.IO
Imports System.Xml
Imports System.Xml.Serialization

Public Class Run
    
    Public Shared Sub Main()
        Dim test As New Run()
        test.SerializeObject("XmlNamespaces.xml")
    End Sub 'Main
    
    Public Sub SerializeObject(filename As String)
        Dim mySerializer As New XmlSerializer(GetType(Books))
        ' Writing a file requires a TextWriter.
        Dim myWriter As New StreamWriter(filename)
        
        ' Creates an XmlSerializerNamespaces and adds two
        ' prefix-namespace pairs. 
        Dim myNamespaces As New XmlSerializerNamespaces()
        myNamespaces.Add("books", "http://www.cpandl.com")
        myNamespaces.Add("money", "http://www.cohowinery.com")
        
        ' Creates a Book.
        Dim myBook As New Book()
        myBook.TITLE = "A Book Title"
        Dim myPrice As New Price()
        myPrice.price = CDec(9.95)
        myPrice.currency = "US Dollar"
        myBook.PRICE = myPrice
        Dim myBooks As New Books()
        myBooks.Book = myBook
        mySerializer.Serialize(myWriter, myBooks, myNamespaces)
        myWriter.Close()
    End Sub
End Class

Public Class Books
    <XmlElement([Namespace] := "http://www.cohowinery.com")> _
    Public Book As Book
End Class 'Books

<XmlType([Namespace] := "http://www.cpandl.com")> _
Public Class Book

    <XmlElement([Namespace] := "http://www.cpandl.com")> _
    Public TITLE As String
    <XmlElement([Namespace] := "http://www.cohowinery.com")> _
    Public PRICE As Price
End Class

Public Class Price
    <XmlAttribute([Namespace] := "http://www.cpandl.com")> _
    Public currency As String
    Public <XmlElement([Namespace] := "http://www.cohowinery.com")> _
        price As Decimal
End Class
using System;
using System.IO;
using System.Xml;
using System.Xml.Serialization;
    
public class Run
{
    public static void Main()
    {
        Run test = new Run();
        test.SerializeObject("XmlNamespaces.xml");
    }
    public void SerializeObject(string filename)
    {
        XmlSerializer mySerializer = new XmlSerializer(typeof(Books));
        // Writing a file requires a TextWriter.
        TextWriter myWriter = new StreamWriter(filename);

        // Creates an XmlSerializerNamespaces and adds two
        // prefix-namespace pairs.
        XmlSerializerNamespaces myNamespaces = 
        new XmlSerializerNamespaces();
        myNamespaces.Add("books", "http://www.cpandl.com");
        myNamespaces.Add("money", "http://www.cohowinery.com");

        // Creates a Book.
        Book myBook = new Book();
        myBook.TITLE = "A Book Title";
        Price myPrice = new Price();
        myPrice.price = (decimal) 9.95;
        myPrice.currency = "US Dollar";
        myBook.PRICE = myPrice;
        Books myBooks = new Books();
        myBooks.Book = myBook;
        mySerializer.Serialize(myWriter,myBooks,myNamespaces);
        myWriter.Close();
    }
}

public class Books
{
    [XmlElement(Namespace = "http://www.cohowinery.com")]
    public Book Book;
}

[XmlType(Namespace ="http://www.cpandl.com")]
public class Book
{
    [XmlElement(Namespace = "http://www.cpandl.com")]
    public string TITLE;
    [XmlElement(Namespace ="http://www.cohowinery.com")]
    public Price PRICE;
}

Vea también

Tareas

Cómo especificar el nombre de un elemento alternativo para una secuencia XML
Cómo serializar un objeto
Cómo deserializar un objeto

Referencia

XmlSerializer (clase)
XmlSerializerNamespaces (clase)

Conceptos

Herramienta Definición de esquemas XML y la serialización XML
Presentación de la serialización XML
Atributos que controlan la serialización XML