方法: Visual Basic .NET での XML スキーマから XML フラグメントを検証します。

文書翻訳 文書翻訳
文書番号: 317463 - 対象製品
すべて展開する | すべて折りたたむ

目次

概要

手順説明を XmlValidatingReader XMLSchemaCollection のオブジェクトを使用して、拡張マークアップ言語 (XML) フラグメント XML スキーマに対して検証する方法します。

XmlValidatingReader XmlReader クラスを実装し、XML データの入力規則のサポートを提供します。 XmlValidatingReader スキーマ プロパティは、 XmlSchemaCollection でキャッシュされたスキーマ ファイル、リーダー接続されます。 XmlValidatingReader ValidationType プロパティは、リーダーを実行する検証の種類を指定します。 ValidationType.None をプロパティを設定する場合、nonvalidating リーダーを作成します。

XML スキーマ定義言語 (XSD) スキーマと XML データの制限 (XDR) スキーマを XmlSchemaCollection にのみ追加できます。 スキーマをロードするのにには名前空間 URI を持つの 追加 メソッドを使用します。 XML スキーマの場合、一般的な名前空間 URI は、スキーマの targetNamespace プロパティです。

要件

必要なハードウェア、ソフトウェア、ネットワーク インフラストラクチャ、Service Pack は次のとおりです:
  • Microsoft Visual Studio .NET を互換性のある Microsoft Windows オペレーティング システムにインストール
この資料は、次のトピックについて詳しい知識のあるユーザーを対象としています:
  • Visual Basic .NET
  • 基本的な XML 標準
  • XSD スキーマ

XSD スキーマを作成します。

C:\Books.xsd という名前の新しいテキスト ファイルに次のコードを貼り付けます:
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="urn:bookstore-schema" elementFormDefault="qualified" targetNamespace="urn:bookstore-schema">
	<xsd:element name="bookstore" type="bookstoreType" />
	<xsd:element name="comment" type="xsd:string" />
	<xsd:element name="author" type="authorName"/>
	<xsd:complexType name="authorName">
		<xsd:sequence>
			<xsd:element name="first-name" type="xsd:string" />
			<xsd:element name="last-name" type="xsd:string" />
		</xsd:sequence>
	</xsd:complexType>
	<xsd:complexType name="bookstoreType">
		<xsd:sequence maxOccurs="unbounded">
			<xsd:element name="book" type="bookType" />
			<xsd:element ref="comment" minOccurs="0" />
		</xsd:sequence>
	</xsd:complexType>
	<xsd:complexType name="bookType">
		<xsd:sequence>
			<xsd:element name="title" type="xsd:string" />
			<xsd:element ref="author" />
			<xsd:element name="price" type="xsd:decimal" />
		</xsd:sequence>
		<xsd:attribute name="genre" type="xsd:string" />
	</xsd:complexType>
	
</xsd:schema>
				

Visual Basic .NET アプリケーションを作成します。

  1. Visual Basic .NET で新しい Windows アプリケーションを作成します。
  2. Form1 には、 Button1 をドラッグします。 次のコード クラス Form1 に、プライベート メンバー変数を追加する貼り付けます:
    Dim m_success As Boolean
    					
  3. 貼り付け、次のサブルーチン手順を XMLValidatingReader オブジェクトに検証エラーを発生させる ValidationEventHandler を作成する:
    Public Sub ValidationEventHandle(ByVal sender As Object, ByVal args As ValidationEventArgs)
            m_success = False
            Console.WriteLine((ControlChars.CrLf & ControlChars.Tab & "Validation error: " & args.Message))
        End Sub 'ValidationEventHandle
    						
    メモ : 検証エラーに関する情報で、データ型定義 (DTD) を XML データ制限 (XDR) を受信するイベント ハンドラーを含める必要がありますスキーマ、および XML スキーマ定義言語 (XSD) スキーマ。 イベント ハンドラーは、このイベントに関連するデータが含まれる ValidationEventArgs 型の引数を受け取ります。

    コールバック ハンドラーを使用して、 ValidationEventArgs.Severity プロパティ XML インスタンス ドキュメントが、スキーマに対して検証することを保証します。 致命的なエラーを示す検証エラー ( 重要度 is equal to XmlSeverityType.Error ) と、検証を区別する、 重要度 プロパティことができます ( 重要度 is equal to XmlSeverityType.Warning ) を使用できるスキーマ情報がないことを示す警告します。
  4. 次のコード、 Button1_Click イベント プロシージャに貼り付けます:
            Dim reader As XmlValidatingReader = Nothing
            Dim myschema As New XmlSchemaCollection()
    
            Try
                'Create the XML fragment to be parsed.
                Dim xmlFrag As String = "<author  xmlns='urn:bookstore-schema' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'>" & _
                                "<first-name>Herman</first-name>" & _
                               "<last-name>Melville</last-name>" & _
                             "</author>"
    
                'Create the XmlParserContext.
                Dim context As New XmlParserContext(Nothing, Nothing, "", XmlSpace.None)
               
                'Implement the reader. 
                reader = New XmlValidatingReader(xmlFrag, XmlNodeType.Element, context)
                'Add the schema.
                myschema.Add("urn:bookstore-schema", "Books.xsd")
    
                'Set the schema type and add the schema to the reader.
                reader.ValidationType = ValidationType.Schema
                reader.Schemas.Add(myschema)
    
                'Add the handler to raise the validation event.
                AddHandler reader.ValidationEventHandler, AddressOf Me.ValidationEventHandle
    
                While reader.Read
    
                End While
                Console.WriteLine("Completed validating xmlfragment")
    
            Catch XmlExp As XmlException
                Console.WriteLine(XmlExp.Message)
            Catch XmlSchExp As XmlSchemaException
                Console.WriteLine(XmlSchExp.Message)
            Catch GenExp As Exception
                Console.WriteLine(GenExp.Message)
            End Try
        End Sub
    					
  5. XML フラグメントは有効な要素で、次のメッセージが、出力ウィンドウに表示されたら、:
    Completed validating xmlfragment
    					
: XMLValidatingReader オブジェクトの型の宣言のみと XML スキーマのトップ レベル要素を検証します。 サブ要素など、XML フラグメントはローカルと見なされます。 最上位の要素としての XML フラグメントを宣言して、必要なレベルでの参照を設定しない限りは XmlValidatingReader に XML フラグメントを直接検証用渡すことはできません。

関連情報

詳細についてはをクリック資料以下の記事の「サポート技術情報」(Microsoft Knowledge Base) を表示します。
307379方法: Visual C# .NET では、DTD、XDR、または XSD を使用して XML ドキュメントを検証します。
313826.NET Framework での XML スキーマの情報: ロードマップ
313651.NET Framework での XML の情報: ロードマップ
詳細については、次の MSDN を参照して Web サイト。
System.Xml 名前空間
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/cpref/html/frlrfsystemxml.asp

使用した XML Web サービス
http://msdn.microsoft.com/xml

プロパティ

文書番号: 317463 - 最終更新日: 2003年9月3日 - リビジョン: 2.2
この資料は以下の製品について記述したものです。
  • Microsoft Visual Basic .NET 2003 Standard Edition
  • Microsoft Visual Basic .NET 2002 Standard Edition
  • Microsoft .NET Framework 1.1
  • Microsoft .NET Framework 1.0
キーワード:?
kbhowtomaster kbmt KB317463 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:317463
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com