XmlSchema XmlSchema XmlSchema XmlSchema Class

Определение

Размещаемое в памяти представление схемы XML в соответствии со спецификациями Схема XML, часть 1. Структуры и Схема XML, часть 2. Типы данных консорциума W3C.An in-memory representation of an XML Schema, as specified in the World Wide Web Consortium (W3C) XML Schema Part 1: Structures and XML Schema Part 2: Datatypes].

public ref class XmlSchema : System::Xml::Schema::XmlSchemaObject
public class XmlSchema : System.Xml.Schema.XmlSchemaObject
type XmlSchema = class
    inherit XmlSchemaObject
Public Class XmlSchema
Inherits XmlSchemaObject
Наследование

Примеры

В следующем примере создается определение схемы.The following example creates a schema definition.

#using <mscorlib.dll>
#using <System.Xml.dll>

using namespace System;
using namespace System::Xml;
using namespace System::Xml::Schema;

class XmlSchemaExamples
{
public:
	static void Main()
	{

		XmlSchema^ schema = gcnew XmlSchema();

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

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

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

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


		// <xs:element name="pets">
		XmlSchemaElement^ elementPets = gcnew XmlSchemaElement();
		schema->Items->Add(elementPets);
		elementPets->Name = "pets";

		// <xs:complexType>
		XmlSchemaComplexType^ complexType = gcnew XmlSchemaComplexType();
		elementPets->SchemaType = complexType;

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

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

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

		XmlSchemaSet^ schemaSet = gcnew XmlSchemaSet();
		schemaSet->ValidationEventHandler += gcnew ValidationEventHandler(ValidationCallbackOne);
		schemaSet->Add(schema);
		schemaSet->Compile();

		XmlSchema^ compiledSchema;

		for each (XmlSchema^ schema1 in schemaSet->Schemas())
		{
			compiledSchema = schema1;
		}

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

	static void ValidationCallbackOne(Object^ sender, ValidationEventArgs^ args)
	{
		Console::WriteLine(args->Message);
	}
};

int main()
{
	XmlSchemaExamples::Main();
	return 0;
};
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);
    }
}
Option Explicit On
Option Strict On

Imports System
Imports System.Xml
Imports System.Xml.Schema

Class XMLSchemaExamples
    Public Shared Sub Main()
        Dim schema As New XmlSchema()

        ' <xs:element name="cat" type="xs:string"/>
        Dim elementCat As 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"/>
        Dim elementDog As 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" />
        Dim elementRedDog As New XmlSchemaElement()
        schema.Items.Add(elementRedDog)
        elementRedDog.Name = "redDog"
        elementRedDog.SubstitutionGroup = New XmlQualifiedName("dog")

        ' <xs:element name="brownDog" substitutionGroup ="dog" />
        Dim elementBrownDog As New XmlSchemaElement()
        schema.Items.Add(elementBrownDog)
        elementBrownDog.Name = "brownDog"
        elementBrownDog.SubstitutionGroup = New XmlQualifiedName("dog")

        ' <xs:element name="pets">
        Dim elementPets As New XmlSchemaElement()
        schema.Items.Add(elementPets)
        elementPets.Name = "pets"

        ' <xs:complexType>
        Dim complexType As New XmlSchemaComplexType()
        elementPets.SchemaType = complexType

        ' <xs:choice minOccurs="0" maxOccurs="unbounded">
        Dim choice As New XmlSchemaChoice()
        complexType.Particle = choice
        choice.MinOccurs = 0
        choice.MaxOccursString = "unbounded"

        ' <xs:element ref="cat"/>
        Dim catRef As New XmlSchemaElement()
        choice.Items.Add(catRef)
        catRef.RefName = New XmlQualifiedName("cat")

        ' <xs:element ref="dog"/>
        Dim dogRef As New XmlSchemaElement()
        choice.Items.Add(dogRef)
        dogRef.RefName = New XmlQualifiedName("dog")

        Dim schemaSet As New XmlSchemaSet()
        AddHandler schemaSet.ValidationEventHandler, AddressOf ValidationCallbackOne

        schemaSet.Add(schema)
        schemaSet.Compile()

        Dim compiledSchema As XmlSchema = Nothing

        For Each schema1 As XmlSchema In schemaSet.Schemas()
            compiledSchema = schema1
        Next

        Dim nsmgr As New XmlNamespaceManager(New NameTable())
        nsmgr.AddNamespace("xs", "http://www.w3.org/2001/XMLSchema")
        compiledSchema.Write(Console.Out, nsmgr)


    End Sub 'Main


    Public Shared Sub ValidationCallbackOne(ByVal sender As Object, ByVal args As ValidationEventArgs)
        Console.WriteLine(args.Message)
    End Sub 'ValidationCallbackOne
End Class 'XMLSchemaExamples

Для предыдущего примера кода создается следующий XML-файл.The following XML file is generated for the preceding code example.


<?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>

Комментарии

Важно!

  • Не используйте схемы из неизвестных или ненадежных источников или расположений.Do not use schemas from unknown or untrusted sources or locations. Это приведет к нарушению безопасности кода.Doing so will compromise the security of your code.
  • Схемы XML (включая встроенные схемы) по сути уязвимы для атак типа "отказ в обслуживании"; не принимайте их в недоверенных сценариях.XML schemas (including inline schemas) are inherently vulnerable to denial of service attacks; do not accept them in untrusted scenarios.
  • Исключения, возникающие в результате использования XmlSchema класса, такого XmlSchemaException как класс, могут содержать конфиденциальные сведения, которые не должны предоставляться в недоверенных сценариях.Exceptions raised as a result of using the XmlSchema class, such as the XmlSchemaException class, may contain sensitive information that should not be exposed in untrusted scenarios. Например, SourceUri свойство XmlSchemaException объекта возвращает путь универсального кода ресурса (URI) к файлу схемы, вызвавшему исключение.For example, the SourceUri property of an XmlSchemaException returns the URI path to the schema file that caused the exception. SourceUri Свойство не должно быть представлено в недоверенных сценариях.The SourceUri property should not be exposed in untrusted scenarios. Исключения должны быть правильно обработаны, поэтому эти конфиденциальные сведения не предоставляются в ненадежных сценариях.Exceptions should be properly handled so this sensitive information is not exposed in untrusted scenarios.

Конструкторы

XmlSchema() XmlSchema() XmlSchema() XmlSchema()

Инициализирует новый экземпляр класса XmlSchema.Initializes a new instance of the XmlSchema class.

Поля

InstanceNamespace InstanceNamespace InstanceNamespace InstanceNamespace

Пространство имен экземпляра схемы XML.The XML schema instance namespace. Это поле является константой.This field is constant.

Namespace Namespace Namespace Namespace

Пространство имен схемы XML.The XML schema namespace. Это поле является константой.This field is constant.

Свойства

AttributeFormDefault AttributeFormDefault AttributeFormDefault AttributeFormDefault

Возвращает или задает форму для атрибутов, объявленных в целевом пространстве имен схемы.Gets or sets the form for attributes declared in the target namespace of the schema.

AttributeGroups AttributeGroups AttributeGroups AttributeGroups

Возвращает значение после компиляции схемы из всех глобальных групп атрибутов в схеме.Gets the post-schema-compilation value of all the global attribute groups in the schema.

Attributes Attributes Attributes Attributes

Получает значение после компиляции схемы всех атрибутов схемы.Gets the post-schema-compilation value for all the attributes in the schema.

BlockDefault BlockDefault BlockDefault BlockDefault

Возвращает или задает атрибут blockDefault, устанавливающий значение по умолчанию атрибута block для типов элементов и сложных типов в targetNamespace схемы.Gets or sets the blockDefault attribute which sets the default value of the block attribute on element and complex types in the targetNamespace of the schema.

ElementFormDefault ElementFormDefault ElementFormDefault ElementFormDefault

Возвращает или задает форму для элементов, объявленных в целевом пространстве имен схемы.Gets or sets the form for elements declared in the target namespace of the schema.

Elements Elements Elements Elements

Возвращает значение после компиляции схемы, состоящее из всех элементов схемы.Gets the post-schema-compilation value for all the elements in the schema.

FinalDefault FinalDefault FinalDefault FinalDefault

Возвращает или задает атрибут finalDefault, устанавливающий значение по умолчанию атрибута final для типов элементов и сложных типов в целевом пространстве имен схемы.Gets or sets the finalDefault attribute which sets the default value of the final attribute on elements and complex types in the target namespace of the schema.

Groups Groups Groups Groups

Получает значение всех групп схемы после компиляции схемы.Gets the post-schema-compilation value of all the groups in the schema.

Id Id Id Id

Возвращает или задает идентификатор строки.Gets or sets the string ID.

Includes Includes Includes Includes

Получает коллекцию включаемых и импортируемых схем.Gets the collection of included and imported schemas.

IsCompiled IsCompiled IsCompiled IsCompiled

Указывает, была ли скомпилирована схема.Indicates if the schema has been compiled.

Items Items Items Items

Получает коллекцию элементов схемы из схемы, а также используется для добавления новых типов элементов на уровне элементов schema.Gets the collection of schema elements in the schema and is used to add new element types at the schema element level.

LineNumber LineNumber LineNumber LineNumber

Получает или задает номер строки в файле, на которую ссылается элемент schema.Gets or sets the line number in the file to which the schema element refers.

(Inherited from XmlSchemaObject)
LinePosition LinePosition LinePosition LinePosition

Получает или задает позицию в строке файла, на которую ссылается элемент schema.Gets or sets the line position in the file to which the schema element refers.

(Inherited from XmlSchemaObject)
Namespaces Namespaces Namespaces Namespaces

Получает или задает XmlSerializerNamespaces для использования с данным объектом схемы.Gets or sets the XmlSerializerNamespaces to use with this schema object.

(Inherited from XmlSchemaObject)
Notations Notations Notations Notations

Получает значение после компиляции схемы всех представлений схемы.Gets the post-schema-compilation value for all notations in the schema.

Parent Parent Parent Parent

Получает или задает родительский элемент данного XmlSchemaObject.Gets or sets the parent of this XmlSchemaObject.

(Inherited from XmlSchemaObject)
SchemaTypes SchemaTypes SchemaTypes SchemaTypes

Получает значение всех типов схемы после компиляции схемы.Gets the post-schema-compilation value of all schema types in the schema.

SourceUri SourceUri SourceUri SourceUri

Получает или задает исходного расположение для файла, загрузившего данную схему.Gets or sets the source location for the file that loaded the schema.

(Inherited from XmlSchemaObject)
TargetNamespace TargetNamespace TargetNamespace TargetNamespace

Возвращает или задает идентификатор URI целевого пространства имен схемы.Gets or sets the Uniform Resource Identifier (URI) of the schema target namespace.

UnhandledAttributes UnhandledAttributes UnhandledAttributes UnhandledAttributes

Получает или задает полные атрибуты, не принадлежащие целевому пространству имен схемы.Gets or sets the qualified attributes which do not belong to the schema target namespace.

Version Version Version Version

Возвращает или задает версию схемы.Gets or sets the version of the schema.

Методы

Compile(ValidationEventHandler) Compile(ValidationEventHandler) Compile(ValidationEventHandler) Compile(ValidationEventHandler)

Компилирует объектную модель схемы XML (SOM — Schema Object Model) в сведения о схеме для проверки.Compiles the XML Schema Object Model (SOM) into schema information for validation. Используется для проверки синтаксической и семантической структуры программно реализованной модели SOM.Used to check the syntactic and semantic structure of the programmatically built SOM. Семантическая проверка допустимости выполняется во время компиляции.Semantic validation checking is performed during compilation.

Compile(ValidationEventHandler, XmlResolver) Compile(ValidationEventHandler, XmlResolver) Compile(ValidationEventHandler, XmlResolver) Compile(ValidationEventHandler, XmlResolver)

Компилирует объектную модель схемы XML (SOM — Schema Object Model) в сведения о схеме для проверки.Compiles the XML Schema Object Model (SOM) into schema information for validation. Используется для проверки синтаксической и семантической структуры программно реализованной модели SOM.Used to check the syntactic and semantic structure of the programmatically built SOM. Семантическая проверка допустимости выполняется во время компиляции.Semantic validation checking is performed during compilation.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, равен ли заданный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Служит хэш-функцией по умолчанию.Serves as the default hash function.

(Inherited from Object)
GetType() GetType() GetType() GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Inherited from Object)
Read(Stream, ValidationEventHandler) Read(Stream, ValidationEventHandler) Read(Stream, ValidationEventHandler) Read(Stream, ValidationEventHandler)

Считывает XML-схему из указанного потока.Reads an XML Schema from the supplied stream.

Read(TextReader, ValidationEventHandler) Read(TextReader, ValidationEventHandler) Read(TextReader, ValidationEventHandler) Read(TextReader, ValidationEventHandler)

Считывает схему XML из предоставленного объекта TextReader.Reads an XML Schema from the supplied TextReader.

Read(XmlReader, ValidationEventHandler) Read(XmlReader, ValidationEventHandler) Read(XmlReader, ValidationEventHandler) Read(XmlReader, ValidationEventHandler)

Считывает схему XML из предоставленного объекта XmlReader.Reads an XML Schema from the supplied XmlReader.

ToString() ToString() ToString() ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Inherited from Object)
Write(Stream) Write(Stream) Write(Stream) Write(Stream)

Записывает схему XML в предоставленный поток данных.Writes the XML Schema to the supplied data stream.

Write(Stream, XmlNamespaceManager) Write(Stream, XmlNamespaceManager) Write(Stream, XmlNamespaceManager) Write(Stream, XmlNamespaceManager)

Выводит схему XML в предоставленный поток Stream с помощью указанного XmlNamespaceManager.Writes the XML Schema to the supplied Stream using the XmlNamespaceManager specified.

Write(TextWriter) Write(TextWriter) Write(TextWriter) Write(TextWriter)

Записывает схему XML в предоставленный объект TextWriter.Writes the XML Schema to the supplied TextWriter.

Write(TextWriter, XmlNamespaceManager) Write(TextWriter, XmlNamespaceManager) Write(TextWriter, XmlNamespaceManager) Write(TextWriter, XmlNamespaceManager)

Записывает схему XML в предоставленный объект TextWriter.Writes the XML Schema to the supplied TextWriter.

Write(XmlWriter) Write(XmlWriter) Write(XmlWriter) Write(XmlWriter)

Записывает схему XML в предоставленный объект XmlWriter.Writes the XML Schema to the supplied XmlWriter.

Write(XmlWriter, XmlNamespaceManager) Write(XmlWriter, XmlNamespaceManager) Write(XmlWriter, XmlNamespaceManager) Write(XmlWriter, XmlNamespaceManager)

Записывает схему XML в предоставленный объект XmlWriter.Writes the XML Schema to the supplied XmlWriter.

Применяется к

Дополнительно