È possibile creare un'istanza XmlReader di convalida utilizzando la classe XmlReaderSettings e il metodo Create.
private bool ValidateXml(string xmlFilePath, string schemaFilePath, string schemaNamespace, Type rootType)
{
XmlSerializer serializer = new XmlSerializer(rootType);
using (var fs = new StreamReader(xmlFilePath, Encoding.GetEncoding("iso-8859-1")))
{
object deserializedObject;
var xmlReaderSettings = new XmlReaderSettings();
if (File.Exists(schemaFilePath))
{
//select schema for validation
xmlReaderSettings.Schemas.Add(schemaNamespace, schemaPath);
xmlReaderSettings.ValidationType = ValidationType.Schema;
try
{
using (var xmlReader = XmlReader.Create(fs, xmlReaderSettings))
{
if (serializer.CanDeserialize(xmlReader))
{
return true;
//deserializedObject = serializer.Deserialize(xmlReader);
}
else
{
return false;
}
}
}
catch(Exception ex)
{ return false; }
}
}
}
Il codice qui sopra un'eccezione se lo schema è valido o non è in grado di deserializzare il codice XML. rootType è il tipo dell'elemento root nella gerarchia di classi equivalente.
Esempio: schema a: XML Schema Tutorial. Salva il file come D:\SampleSchema.xsd
.
Run xsd.exe
:
- Open 'Menu Avvio> Tutti i programmi> Microsoft Visual Studio 2010> Visual Studio Tools> Visual Studio 2010 Command Prompt'
- Nel prompt dei comandi digitare:
xsd.exe /c /out:D:\ "D:\SampleSchema.xsd"
- opzioni xsd: l'opzione
/out
è specificare la directory di output, /c
è specificare lo strumento per generare le classi
- La gerarchia delle classi di output è presente a
D:\SampleSchema.cs
- La gerarchia delle classi generata sembra qualche cosa come questa,
//------------------------------------------------------------------------------
//
// This code was generated by a tool.
// Runtime Version:2.0.50727.4952
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
//
//------------------------------------------------------------------------------
using System.Xml.Serialization;
//
// This source code was auto-generated by xsd, Version=2.0.50727.3038.
//
///
[System.CodeDom.Compiler.GeneratedCodeAttribute("xsd", "2.0.50727.3038")]
[System.SerializableAttribute()]
[System.Diagnostics.DebuggerStepThroughAttribute()]
[System.ComponentModel.DesignerCategoryAttribute("code")]
[System.Xml.Serialization.XmlTypeAttribute(AnonymousType=true)]
[System.Xml.Serialization.XmlRootAttribute(Namespace="", IsNullable=false)]
public partial class note {
private string toField;
private string fromField;
private string headingField;
private string bodyField;
///
[System.Xml.Serialization.XmlElementAttribute(Form=System.Xml.Schema.XmlSchemaForm.Unqualified)]
public string to {
get {
return this.toField;
}
set {
this.toField = value;
}
}
///
[System.Xml.Serialization.XmlElementAttribute(Form=System.Xml.Schema.XmlSchemaForm.Unqualified)]
public string from {
get {
return this.fromField;
}
set {
this.fromField = value;
}
}
///
[System.Xml.Serialization.XmlElementAttribute(Form=System.Xml.Schema.XmlSchemaForm.Unqualified)]
public string heading {
get {
return this.headingField;
}
set {
this.headingField = value;
}
}
///
[System.Xml.Serialization.XmlElementAttribute(Form=System.Xml.Schema.XmlSchemaForm.Unqualified)]
public string body {
get {
return this.bodyField;
}
set {
this.bodyField = value;
}
}
}
aggiungere la classe al progetto di Visual Studio.
Per il precedente esempio xsd, la classe radice è note
.
chiamata al metodo,
bool isXmlValid = ValidateXml(@"D:\Sample.xml",
@"D:\SampleSchema.xsd",
@"http://www.w3.org/2001/XMLSchema",
typeof(note));
Maggiori informazioni:
fonte
2011-01-03 11:58:33
Grazie, è esattamente quello di cui avevo bisogno anche io! – M3NTA7
Incredibilmente semplice rispetto ad altre soluzioni là fuori, grazie! – JBeagle
'validate' dovrebbe essere con la prima lettera maiuscola ... – realsonic