XML Schema Validator Class (from UABv2.0)

发表于:2007-06-30来源:作者:点击数: 标签:
这里有一个 XML 架构验证类,摘自 。 源码: //============================================================================================================ // Microsoft Updater Application Block for .NET // // // SchemaValidator.cs // // Cont
 

这里有一个 XML 架构验证类,摘自 。

源码:

//============================================================================================================
// Microsoft Updater Application Block for .NET
// 
// 
// 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 suclearcase/" target="_blank" >cceeded 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;
  }


原文转自:http://www.ltesting.net