Puede crear una instancia de validación de XmlReader utilizando la clase XmlReaderSettings y el método 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; }
}
}
}
El código anterior una excepción si el esquema es válido o no es capaz de deserializar el XML. rootType es el tipo del elemento raíz en la jerarquía de clases equivalente.
Ejemplo: esquema en: XML Schema Tutorial. Guarde el archivo como D:\SampleSchema.xsd
.
Run xsd.exe
:
- 'menú Inicio> Todos los programas> Microsoft Visual Studio 2010> Visual Studio Tools> Visual Studio 2010 Símbolo del sistema' Open
- En el símbolo del sistema, escriba:
xsd.exe /c /out:D:\ "D:\SampleSchema.xsd"
- opciones xsd:
/out
opción es especificar el directorio de salida, /c
es especificar la herramienta para generar clases
- La jerarquía de clase de salida está presente en
D:\SampleSchema.cs
- La jerarquía de clases generada se ve algo como esto,
//------------------------------------------------------------------------------
//
// 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;
}
}
}
Añadir la clase al proyecto de Visual Studio.
Para la muestra de xsd anterior, la clase de raíz es note
.
Llame al método,
bool isXmlValid = ValidateXml(@"D:\Sample.xml",
@"D:\SampleSchema.xsd",
@"http://www.w3.org/2001/XMLSchema",
typeof(note));
Más información:
¡Gracias, eso es exactamente lo que necesitaba también! – M3NTA7
Sorprendentemente simple en comparación con otras soluciones, ¡gracias! – JBeagle
'validate' debe ser con mayúscula inicial ... – realsonic