Walidacja schematu XML (XSD) przy użyciu elementu XmlSchemaSet
Dokumenty XML można zweryfikować względem schematu języka definicji schematu XML (XSD) w pliku XmlSchemaSet.
Weryfikowanie dokumentów XML
Dokumenty XML są weryfikowane przez Create metodę XmlReader klasy . Aby zweryfikować dokument XML, skonstruuj XmlReaderSettings obiekt zawierający schemat języka definicji schematu XML (XSD), za pomocą którego ma być weryfikowany dokument XML.
Uwaga
System.Xml.Schema Przestrzeń nazw zawiera metody rozszerzeń, które ułatwiają weryfikowanie drzewa XML względem pliku XSD w przypadku używania linQ to XML (C#) i LINQ to XML (Visual Basic). Aby uzyskać więcej informacji na temat sprawdzania poprawności dokumentów XML przy użyciu linQ to XML, zobacz Jak zweryfikować użycie XSD (LINQ to XML) (C#) i How to: Validate Using XSD (LINQ to XML) (Visual Basic) (Weryfikowanie przy użyciu XSD (LINQ to XML) (Visual Basic).
Pojedynczy schemat lub zestaw schematów (jako XmlSchemaSet) można dodać do obiektu XmlSchemaSet , przekazując jeden jako parametr do Add metody XmlSchemaSet. Podczas sprawdzania poprawności dokumentu docelowa przestrzeń nazw dokumentu musi być zgodna z docelową przestrzenią nazw schematu w zestawie schematów.
Poniżej przedstawiono przykładowy dokument XML.
<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>
Poniżej znajduje się schemat, który weryfikuje przykładowy dokument XML.
<?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>
W poniższym przykładzie kodu powyższy schemat jest dodawany do Schemas właściwości XmlReaderSettings obiektu. Obiekt XmlReaderSettings jest przekazywany jako parametr do Create metody XmlReader obiektu, który weryfikuje powyższy dokument XML.
Właściwość ValidationTypeXmlReaderSettings obiektu jest ustawiona na wartość , aby wymusić Schema
walidację dokumentu XML za pomocą Create metody XmlReader obiektu. Element ValidationEventHandler jest dodawany do XmlReaderSettings obiektu w celu obsługi wszelkich zdarzeń Warning zgłaszanych Error przez błędy występujące podczas procesu weryfikacji zarówno dokumentu XML, jak i schematu.
#using <System.Xml.dll>
using namespace System;
using namespace System::Xml;
using namespace System::Xml::Schema;
static void booksSettingsValidationEventHandler( Object^ /*sender*/, ValidationEventArgs^ e )
{
if ( e->Severity == XmlSeverityType::Warning )
{
Console::Write( L"WARNING: " );
Console::WriteLine( e->Message );
}
else
if ( e->Severity == XmlSeverityType::Error )
{
Console::Write( L"ERROR: " );
Console::WriteLine( e->Message );
}
}
int main()
{
XmlReaderSettings^ booksSettings = gcnew XmlReaderSettings;
booksSettings->Schemas->Add( L"http://www.contoso.com/books", L"books.xsd" );
booksSettings->ValidationType = ValidationType::Schema;
booksSettings->ValidationEventHandler += gcnew ValidationEventHandler( booksSettingsValidationEventHandler );
XmlReader^ books = XmlReader::Create( L"books.xml", booksSettings );
while ( books->Read() )
{}
return 0;
}
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