英語で読む

次の方法で共有


XmlSchema クラス

定義

World Wide Web コンソーシアム (W3C) の『XML スキーマ、パート 1: 構造体』および『XML スキーマ、パート 2: データ型]』で指定されている XML スキーマのメモリ内表現です。

public class XmlSchema
public class XmlSchema : System.Xml.Schema.XmlSchemaObject
継承
XmlSchema
継承

次の例では、スキーマ定義を作成します。

using System;
using System.Xml;
using System.Xml.Schema;

class XMLSchemaExamples
{
    public static void Main()
    {

        XmlSchema schema = new XmlSchema();

        // <xs:element name="cat" type="xs:string"/>
        XmlSchemaElement elementCat = new XmlSchemaElement();
        schema.Items.Add(elementCat);
        elementCat.Name = "cat";
        elementCat.SchemaTypeName = new XmlQualifiedName("string", "http://www.w3.org/2001/XMLSchema");

        // <xs:element name="dog" type="xs:string"/>
        XmlSchemaElement elementDog = new XmlSchemaElement();
        schema.Items.Add(elementDog);
        elementDog.Name = "dog";
        elementDog.SchemaTypeName = new XmlQualifiedName("string", "http://www.w3.org/2001/XMLSchema");

        // <xs:element name="redDog" substitutionGroup="dog" />
        XmlSchemaElement elementRedDog = new XmlSchemaElement();
        schema.Items.Add(elementRedDog);
        elementRedDog.Name = "redDog";
        elementRedDog.SubstitutionGroup = new XmlQualifiedName("dog");

        // <xs:element name="brownDog" substitutionGroup ="dog" />
        XmlSchemaElement elementBrownDog = new XmlSchemaElement();
        schema.Items.Add(elementBrownDog);
        elementBrownDog.Name = "brownDog";
        elementBrownDog.SubstitutionGroup = new XmlQualifiedName("dog");

        // <xs:element name="pets">
        XmlSchemaElement elementPets = new XmlSchemaElement();
        schema.Items.Add(elementPets);
        elementPets.Name = "pets";

        // <xs:complexType>
        XmlSchemaComplexType complexType = new XmlSchemaComplexType();
        elementPets.SchemaType = complexType;

        // <xs:choice minOccurs="0" maxOccurs="unbounded">
        XmlSchemaChoice choice = new XmlSchemaChoice();
        complexType.Particle = choice;
        choice.MinOccurs = 0;
        choice.MaxOccursString = "unbounded";

        // <xs:element ref="cat"/>
        XmlSchemaElement catRef = new XmlSchemaElement();
        choice.Items.Add(catRef);
        catRef.RefName = new XmlQualifiedName("cat");

        // <xs:element ref="dog"/>
        XmlSchemaElement dogRef = new XmlSchemaElement();
        choice.Items.Add(dogRef);
        dogRef.RefName = new XmlQualifiedName("dog");

        XmlSchemaSet schemaSet = new XmlSchemaSet();
        schemaSet.ValidationEventHandler += new ValidationEventHandler(ValidationCallbackOne);
        schemaSet.Add(schema);
        schemaSet.Compile();

        XmlSchema compiledSchema = null;

        foreach (XmlSchema schema1 in schemaSet.Schemas())
        {
            compiledSchema = schema1;
        }

        XmlNamespaceManager nsmgr = new XmlNamespaceManager(new NameTable());
        nsmgr.AddNamespace("xs", "http://www.w3.org/2001/XMLSchema");
        compiledSchema.Write(Console.Out, nsmgr);
    }

    public static void ValidationCallbackOne(object sender, ValidationEventArgs args)
    {
        Console.WriteLine(args.Message);
    }
}

前のコード例では、次の XML ファイルが生成されます。


<?xml version="1.0" encoding="IBM437"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
    <xs:element name="cat" type="xs:string"/>
    <xs:element name="dog" type="xs:string"/>
    <xs:element name="redDog" type="xs:string" substitutionGroup="dog"/>
    <xs:element name="brownDog" type="xs:string" substitutionGroup ="dog" />

    <xs:element name="pets">
      <xs:complexType>
        <xs:choice minOccurs="0" maxOccurs="unbounded">
          <xs:element ref="cat"/>
          <xs:element ref="dog"/>
        </xs:choice>
      </xs:complexType>
    </xs:element>
</xs:schema>

注釈

重要

  • 不明または信頼されていないソースまたは場所のスキーマは使用しないでください。 これにより、コードのセキュリティが損なわれます。
  • XML スキーマ (インライン スキーマを含む) は、本質的にサービス拒否攻撃に対して脆弱です。信頼されていないシナリオでは受け入れないでください。
  • クラス (クラスなど) を使用した結果として発生するXmlSchemaXmlSchemaException例外には、信頼されていないシナリオで公開すべきではない機密情報が含まれている場合があります。 たとえば、 の XmlSchemaException プロパティはSourceUri、例外の原因となったスキーマ ファイルへの URI パスを返します。 SourceUri信頼されていないシナリオでは、 プロパティを公開しないでください。 この機密情報が信頼されていないシナリオで公開されないように、例外を適切に処理する必要があります。

コンストラクター

XmlSchema()

XmlSchema クラスの新しいインスタンスを初期化します。

フィールド

InstanceNamespace

XML スキーマ インスタンスの名前空間。 このフィールドは定数です。

Namespace

XML スキーマの名前空間。 このフィールドは定数です。

プロパティ

AttributeFormDefault

スキーマのターゲット名前空間で宣言された属性の形式を取得または設定します。

AttributeGroups

スキーマ内のすべてのグローバル属性グループについて、スキーマ コンパイル後の値を取得します。

Attributes

スキーマ内のすべての属性について、スキーマ コンパイル後の値を取得します。

BlockDefault

スキーマの blockDefault の要素および複合型に対し、block 属性の既定値を設定する targetNamespace 属性を取得または設定します。

ElementFormDefault

スキーマのターゲット名前空間で宣言された要素の形式を取得または設定します。

Elements

スキーマ内のすべての要素について、スキーマ コンパイル後の値を取得します。

FinalDefault

スキーマのターゲット名前空間の要素および複合型に対し、finalDefault 属性の既定値を設定する final 属性を取得または設定します。

Groups

スキーマ内のすべてのグループについて、スキーマ コンパイル後の値を取得します。

Id

文字列 ID を取得または設定します。

Includes

インクルードされたスキーマとインポートされたスキーマのコレクションを取得します。

IsCompiled

スキーマがコンパイル済みかどうかを示します。

Items

スキーマに含まれるスキーマ要素コレクションを取得します。新しい要素型を schema 要素レベルで追加する場合に使用します。

LineNumber

schema 要素が参照するファイルの行番号を取得または設定します。

(継承元 XmlSchemaObject)
LinePosition

schema 要素が参照するファイルの行番号を取得または設定します。

(継承元 XmlSchemaObject)
Namespaces

このスキーマ オブジェクトと一緒に使用する XmlSerializerNamespaces を取得または設定します。

(継承元 XmlSchemaObject)
Notations

スキーマ内のすべての注釈について、スキーマ コンパイル後の値を取得します。

Parent

この XmlSchemaObject の親を取得または設定します。

(継承元 XmlSchemaObject)
SchemaTypes

スキーマ内のすべてのスキーマ型について、スキーマ コンパイル後の値を取得します。

SourceUri

スキーマを読み込んだファイルのソース位置を取得または設定します。

(継承元 XmlSchemaObject)
TargetNamespace

スキーマのターゲット名前空間の URI (Uniform Resource Identifier) を取得または設定します。

UnhandledAttributes

スキーマのターゲット名前空間に属さない、修飾された属性を取得または設定します。

Version

スキーマのバージョンを取得または設定します。

メソッド

Compile(ValidationEventHandler)
古い.
古い.
古い.

XML SOM (Schema Object Model) を検証用のスキーマ情報にコンパイルします。 プログラムによって構築された SOM の構文および意味構造をチェックするために使用します。 意味検証チェックは、コンパイル時に実行されます。

Compile(ValidationEventHandler, XmlResolver)
古い.
古い.
古い.

XML SOM (Schema Object Model) を検証用のスキーマ情報にコンパイルします。 プログラムによって構築された SOM の構文および意味構造をチェックするために使用します。 意味検証チェックは、コンパイル時に実行されます。

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。

(継承元 Object)
GetHashCode()

既定のハッシュ関数として機能します。

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。

(継承元 Object)
Read(Stream, ValidationEventHandler)

指定されたストリームから XML スキーマを読み取ります。

Read(TextReader, ValidationEventHandler)

提供された TextReader から XML スキーマを読み込みます。

Read(XmlReader, ValidationEventHandler)

提供された XmlReader から XML スキーマを読み込みます。

ToString()

現在のオブジェクトを表す文字列を返します。

(継承元 Object)
Write(Stream)

提供されたデータ ストリームに XML スキーマを書き込みます。

Write(Stream, XmlNamespaceManager)

指定された Stream を使用し、指定された XmlNamespaceManager に XML スキーマを書き込みます。

Write(TextWriter)

提供された TextWriter に XML スキーマを書き込みます。

Write(TextWriter, XmlNamespaceManager)

提供された TextWriter に XML スキーマを書き込みます。

Write(XmlWriter)

提供された XmlWriter に XML スキーマを書き込みます。

Write(XmlWriter, XmlNamespaceManager)

提供された XmlWriter に XML スキーマを書き込みます。

適用対象

製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

こちらもご覧ください