XML Schema Validator Class (from UABv2.0)

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

这里有一个 XML 架构验证类,摘自 Microsoft Updater Application Block v2.0

源码://============================================================================================================

// Microsoft Updater Application Block for .NET

// http://msdn.microsoft.com/library/en-us/dnbda/html/updater.asp

//

// SchemaValidator.cs

//

// Contains the implementation of the schema validator.

//

// For more information see the Updater Application Block Implementation Overview.

//

//============================================================================================================

// Copyright ?Microsoft Corporation. All rights reserved.

// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY

// OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT

// LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY AND

// FITNESS FOR A PARTICULAR PURPOSE.

//============================================================================================================

using System;

using System.Collections;

using System.IO;

using System.Xml;

using System.Xml.Schema;

namespace Microsoft.ApplicationBlocks.Updater.Utilities

{

/// <summary>

/// Helper class to perform schema validations.

/// </summary>

public sealed class SchemaValidator

{

#region Private members

/// <summary>

/// The schemas that will be used for validation.

/// </summary>

private ArrayList schemas = new ArrayList(2);

/// <summary>

/// The errors detected during the validation.

/// </summary>

private ArrayList errors = new ArrayList(5);

/// <summary>

/// Whether the document is valid or not.

/// </summary>

private bool isValid;

#endregion

#region Constructors

/// <summary>

/// Creates an instance of the SchemaValidator using the document and the schemas.

/// </summary>

/// <param name="document">The document to validate.</param>

/// <param name="schemas">A list of schemas to validate the document against.</param>

public SchemaValidator( string document, params Stream[] schemas )

{

this.schemas.Add( document );

foreach(Stream s in schemas)

{

this.schemas.Add( s );

}

isValid = true;

}

#endregion

#region Public members

/// <summary>

/// Validates the document and returns the result of the validation.

/// </summary>

/// <returns><c>true</c> if the document have succeeded the validation, otherwise <c>false</c>.</returns>

public bool Validate()

{

errors.Clear();

XmlValidatingReader vr = null;

object doc = schemas[0];

if ( doc is Stream)

{

vr = new XmlValidatingReader( (Stream)doc, XmlNodeType.Element, null );

}

else if ( doc is String )

{

vr = new XmlValidatingReader( (string)doc, XmlNodeType.Element, null );

}

try

{

for(int i=1;i<schemas.Count;i++)

{

vr.Schemas.Add( null, new XmlTextReader( (Stream)schemas[i] ) );

}

vr.ValidationEventHandler += new System.Xml.Schema.ValidationEventHandler(ValidationEventHandler);

while( vr.Read() );

return isValid;

}

finally

{

vr.Close();

}

}

/// <summary>

/// Contains the validation errors encountered in the last validation operation.

/// </summary>

public ValidationEventArgs[] Errors

{

get

{

return (ValidationEventArgs[])errors.ToArray(typeof(ValidationEventArgs) );

}

}

/// <summary>

/// Helper method to capture the event handlers.

/// </summary>

/// <param name="sender">The sender of the event.</param>

/// <param name="e">The information about the event.</param>

private void ValidationEventHandler(object sender, System.Xml.Schema.ValidationEventArgs e)

{

errors.Add( e );

if ( e.Severity == XmlSeverityType.Warning )

{

return;

}

isValid = false;

}

#endregion

}

}

使用: /// <summary>

/// Download and validates the manifest using the Uri location.

/// </summary>

/// <param name="type">The type that represents the manifest class.</param>

/// <param name="location">The location of the manifest.</param>

/// <param name="schemaResource">The resource where the embedded XSD resides in the assembly.</param>

/// <returns>The Manifest instance.</returns>

[SecurityPermission(SecurityAction.Demand, SerializationFormatter=true)]

private object ValidateAndDeserialize( Type type, Uri location, string schemaResource )

{

object result = null;

try

{

string doc = DownloadFile( location );

using ( Stream schema = Assembly.GetExecutingAssembly().GetManifestResourceStream( schemaResource ) )

{

SchemaValidator validator = new SchemaValidator( doc, schema );

if ( !validator.Validate() )

{

Logger.LogAndThrowException( new ApplicationUpdaterException( Resource.ResourceManager[ Resource.MessageKey.ManifestSchemaError, location, schemaResource ] ) );

}

XmlSerializer xser = new XmlSerializer( type );

result = xser.Deserialize( new XmlTextReader( doc, XmlNodeType.Document, null) );

}

}

catch( Exception ex )

{

Logger.LogAndThrowException( ex );

}

return result;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有