Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
L'API SOM (Schema Object Model) può essere utilizzata per leggere e scrivere schemi XSD (XML Schema Definition Language) da file o altre fonti e costruire schemi XML in memoria utilizzando le classi presenti nello spazio dei nomi System.Xml.Schema che mappano sulle strutture definite nella Raccomandazione XML Schema del World Wide Web Consortium (W3C).
Lettura e scrittura di XML Schema
La classe XmlSchema fornisce i metodi Read e Write per leggere e scrivere schemi XML. Il Read metodo restituisce un XmlSchema oggetto che rappresenta lo schema XML e accetta un oggetto facoltativo ValidationEventHandler come parametro per gestire gli avvisi e gli errori di convalida dello schema rilevati durante la lettura di uno schema XML.
Il metodo Write scrive schemi XML agli oggetti Stream, TextWriter e XmlWriter e può accettare un oggetto XmlNamespaceManager opzionale come parametro. Un XmlNamespaceManager viene utilizzato per gestire i namespace rilevati in uno schema XML. Per altre informazioni sulla XmlNamespaceManager classe , vedere Gestione degli spazi dei nomi in un documento XML.
Nell'esempio di codice seguente viene illustrata la lettura e la scrittura di XML Schema da e in un file. L'esempio di codice prende il file example.xsd
, lo legge in un oggetto XmlSchema usando il metodo static
Read, e poi scrive il file sulla console e in un nuovo file new.xsd
. Nell'esempio di codice viene inoltre fornito un oggetto ValidationEventHandler come parametro per il static
Read metodo per gestire eventuali avvisi o errori di convalida dello schema rilevati durante la lettura di XML Schema.
ValidationEventHandler Se non viene specificato (null
), non vengono segnalati avvisi o errori.
using System;
using System.IO;
using System.Text;
using System.Xml;
using System.Xml.Schema;
class XmlSchemaReadWriteExample
{
static void Main()
{
try
{
XmlTextReader reader = new XmlTextReader("example.xsd");
XmlSchema schema = XmlSchema.Read(reader, ValidationCallback);
schema.Write(Console.Out);
FileStream file = new FileStream("new.xsd", FileMode.Create, FileAccess.ReadWrite);
XmlTextWriter xwriter = new XmlTextWriter(file, new UTF8Encoding());
xwriter.Formatting = Formatting.Indented;
schema.Write(xwriter);
}
catch(Exception e)
{
Console.WriteLine(e);
}
}
static void ValidationCallback(object sender, ValidationEventArgs args)
{
if (args.Severity == XmlSeverityType.Warning)
Console.Write("WARNING: ");
else if (args.Severity == XmlSeverityType.Error)
Console.Write("ERROR: ");
Console.WriteLine(args.Message);
}
}
Imports System.IO
Imports System.Text
Imports System.Xml
Imports System.Xml.Schema
Class XmlSchemaReadWriteExample
Shared Sub Main()
Try
Dim reader As XmlTextReader = New XmlTextReader("example.xsd")
Dim myschema As XmlSchema = XmlSchema.Read(reader, AddressOf ValidationCallback)
myschema.Write(Console.Out)
Dim file As FileStream = New FileStream("new.xsd", FileMode.Create, FileAccess.ReadWrite)
Dim xwriter As XmlTextWriter = New XmlTextWriter(file, New UTF8Encoding())
xwriter.Formatting = Formatting.Indented
myschema.Write(xwriter)
Catch e As Exception
Console.WriteLine(e)
End Try
End Sub
Shared Sub ValidationCallback(ByVal sender As Object, ByVal args As ValidationEventArgs)
If args.Severity = XmlSeverityType.Warning Then
Console.Write("WARNING: ")
Else
If args.Severity = XmlSeverityType.Error Then
Console.Write("ERROR: ")
End If
End If
Console.WriteLine(args.Message)
End Sub
End Class
L'esempio prende example.xsd
come input.
<?xml version="1.0"?>
<xs:schema id="play" targetNamespace="http://tempuri.org/play.xsd" elementFormDefault="qualified" xmlns="http://tempuri.org/play.xsd" xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name='myShoeSize'>
<xs:complexType>
<xs:simpleContent>
<xs:extension base='xs:decimal'>
<xs:attribute name='sizing' type='xs:string' />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
</xs:schema>