XmlSerializerNamespaces-Klasse
Enthält die XML-Namespaces und Präfixe, die von XmlSerializer zum Generieren vollständiger Namen in einer XML-Dokumentinstanz verwendet werden.
Namespace: System.Xml.Serialization
Assembly: System.Xml (in system.xml.dll)
Syntax
'Declaration
Public Class XmlSerializerNamespaces
'Usage
Dim instance As XmlSerializerNamespaces
public class XmlSerializerNamespaces
public ref class XmlSerializerNamespaces
public class XmlSerializerNamespaces
public class XmlSerializerNamespaces
Hinweise
XmlSerializerNamespaces enthält eine Auflistung von XML-Namespaces, denen jeweils ein Präfix zugeordnet ist. Der XmlSerializer verwendet eine Instanz der XmlSerializerNamespaces-Klasse, um gekennzeichnete Namen in einem XML-Dokument zu erstellen.
Die in XmlSerializerNamespaces enthaltenen XML-Namespaces müssen der durch www.w3.org angegebenen Spezifikation Namespaces in XML entsprechen.
XML-Namespaces stellen ein Verfahren für die Kennzeichnung der Namen von XML-Elementen und -Attributen in XML-Dokumenten bereit. Ein vollständiger (qualifizierter) Name besteht aus einem Präfix und einem lokalen Namen, die durch einen Doppelpunkt getrennt sind. Das Präfix wird nur als Platzhalter verwendet und ist einem URI zugeordnet, der den Namespace angibt. Die Kombination aus dem global verwalteten URI-Namespace und dem lokalen Namen bildet einen weltweit garantiert eindeutigen Namen.
So erstellen Sie vollständige Namen in einem XML-Dokument:
Erstellen Sie eine XmlSerializerNamespaces-Instanz.
Fügen Sie der Instanz mit Add die gewünschten Paare aus Präfix und Namespace hinzu.
Wenden Sie auf die einzelnen Eigenschaften oder Klassen, die vom XmlSerializer in ein XML-Dokument serialisiert werden, das entsprechende .NET-Attribut an. Die folgenden Attribute stehen zur Verfügung:
Legen Sie die Namespace-Eigenschaft jedes Attributs auf einen der Namespacewerte aus dem XmlSerializerNamespaces-Objekt fest.
Übergeben Sie XmlSerializerNamespaces an die Serialize-Methode von XmlSerializer.
Hinweis
Die Erstellung eines leeren Paars aus Namespace und Präfix wird nicht unterstützt. Das heißt, Sie können mit dem folgenden Code kein Paar erstellen:
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("", "");
Dim ns As XmlSerializerNamespaces ns = New XmlSerializerNamespaces()
ns.Add("", "")
Beispiel
Im folgenden Beispiel wird ein XmlSerializerNamespaces-Objekt erstellt, dem zwei Paare aus Präfix und Namespace hinzugefügt werden. Im Beispiel wird XmlSerializerNamespaces anschließend an die Serialize-Methode übergeben, die ein Books-Objekt in ein XML-Dokument serialisiert. Die Serialize-Methode verwendet das XmlSerializerNamespaces-Objekt und erstellt einen vollständigen Namen für jedes XML-Element und -Attribut mit einem der beiden Namespaces.
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
Public Sub SerializeObject(ByVal filename As String)
Dim s As New XmlSerializer(GetType(Books))
' Writing a file requires a TextWriter.
Dim t As New StreamWriter(filename)
' Create an XmlSerializerNamespaces object and add two
' prefix-namespace pairs.
Dim ns As New XmlSerializerNamespaces()
ns.Add("books", "http://www.cpandl.com")
ns.Add("money", "http://www.cohowinery.com")
' Create a Book instance.
Dim b As New Book()
b.TITLE = "A Book Title"
Dim p As New Price()
p.price = CDec(9.95)
p.currency = "US Dollar"
b.PRICE = p
Dim bks As New Books()
bks.Book = b
s.Serialize(t, bks, ns)
t.Close()
End Sub
End Class
Public Class Books
<XmlElement(Namespace := "http://www.cohowinery.com")> _
Public Book As Book
End Class
<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
<XmlElement(Namespace := "http://www.cohowinery.com")> _
Public 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 s = new XmlSerializer(typeof(Books));
// Writing a file requires a TextWriter.
TextWriter t = new StreamWriter(filename);
/* Create an XmlSerializerNamespaces object and add two
prefix-namespace pairs. */
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("books", "http://www.cpandl.com");
ns.Add("money", "http://www.cohowinery.com");
// Create a Book instance.
Book b = new Book();
b.TITLE = "A Book Title";
Price p = new Price();
p.price = (decimal) 9.95;
p.currency = "US Dollar";
b.PRICE = p;
Books bks = new Books();
bks.Book = b;
s.Serialize(t,bks,ns);
t.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;
}
public class Price
{
[XmlAttribute(Namespace = "http://www.cpandl.com")]
public string currency;
[XmlElement(Namespace = "http://www.cohowinery.com")]
public decimal price;
}
#using <System.Xml.dll>
#using <System.dll>
using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Xml::Serialization;
public ref class Price
{
public:
[XmlAttributeAttribute(Namespace="http://www.cpandl.com")]
String^ currency;
[XmlElement(Namespace="http://www.cohowinery.com")]
Decimal price;
};
[XmlType(Namespace="http://www.cpandl.com")]
public ref class Book
{
public:
[XmlElement(Namespace="http://www.cpandl.com")]
String^ TITLE;
[XmlElement(Namespace="http://www.cohowinery.com")]
Price^ PRICE;
};
public ref class Books
{
public:
[XmlElement(Namespace="http://www.cohowinery.com")]
Book^ Book;
};
public ref class Run
{
public:
static void main()
{
Run^ test = gcnew Run;
test->SerializeObject( "XmlNamespaces.xml" );
}
void SerializeObject( String^ filename )
{
XmlSerializer^ s = gcnew XmlSerializer( Books::typeid );
// Writing a file requires a TextWriter.
TextWriter^ t = gcnew StreamWriter( filename );
/* Create an XmlSerializerNamespaces object and add two
prefix-namespace pairs. */
XmlSerializerNamespaces^ ns = gcnew XmlSerializerNamespaces;
ns->Add( "books", "http://www.cpandl.com" );
ns->Add( "money", "http://www.cohowinery.com" );
// Create a Book instance.
Book^ b = gcnew Book;
b->TITLE = "A Book Title";
Price^ p = gcnew Price;
p->price = (Decimal)9.95;
p->currency = "US Dollar";
b->PRICE = p;
Books^ bks = gcnew Books;
bks->Book = b;
s->Serialize( t, bks, ns );
t->Close();
}
};
int main()
{
Run::main();
}
import System.*;
import System.IO.*;
import System.Xml.*;
import System.Xml.Serialization.*;
public class Run
{
public static void main(String[] args)
{
Run test = new Run();
test.SerializeObject("XmlNamespaces.xml");
} //main
public void SerializeObject(String filename)
{
XmlSerializer s = new XmlSerializer(Books.class.ToType());
// Writing a file requires a TextWriter.
TextWriter t = new StreamWriter(filename);
/* Create an XmlSerializerNamespaces object and add two
prefix-namespace pairs. */
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("books", "http://www.cpandl.com");
ns.Add("money", "http://www.cohowinery.com");
// Create a Book instance.
Book b = new Book();
b.title = "A Book Title";
Price p = new Price();
p.price = Convert.ToDecimal(9.95);
p.currency = "US Dollar";
b.price = p;
Books bks = new Books();
bks.book = b;
s.Serialize(t, bks, ns);
t.Close();
} //SerializeObject
} //Run
public class Books
{
/** @attribute XmlElement(Namespace = "http://www.cohowinery.com")
*/
public Book book;
} //Books
/** @attribute XmlType(Namespace = "http://www.cpandl.com")
*/
public class Book
{
/** @attribute XmlElement(Namespace = "http://www.cpandl.com")
*/
public String title;
/** @attribute XmlElement(Namespace = "http://www.cohowinery.com")
*/
public Price price;
} //Book
public class Price
{
/** @attribute XmlAttribute(Namespace = "http://www.cpandl.com")
*/
public String currency;
/** @attribute XmlElement(Namespace = "http://www.cohowinery.com")
*/
public System.Decimal price;
} //Price
Vererbungshierarchie
System.Object
System.Xml.Serialization.XmlSerializerNamespaces
Threadsicherheit
Alle öffentlichen statischen (Shared in Visual Basic) Member dieses Typs sind threadsicher. Bei Instanzmembern ist die Threadsicherheit nicht gewährleistet.
Plattformen
Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile für Pocket PC, Windows Mobile für Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
.NET Compact Framework
Unterstützt in: 2.0, 1.0
Siehe auch
Referenz
XmlSerializerNamespaces-Member
System.Xml.Serialization-Namespace
XmlAttributes-Klasse
Weitere Ressourcen
Einführung in die XML-Serialisierung
Gewusst wie: Angeben eines alternativen Elementnamens für einen XML-Stream
Steuern der XML-Serialisierung mit Attributen
Beispiele für die XML-Serialisierung
XML Schema Definition-Tool (Xsd.exe)