XsdDataContractExporter Classe

Definição

Permite a transformação de um conjunto de tipos de .NET usados em contratos de dados em um arquivo de esquema XML (.xsd).

public ref class XsdDataContractExporter
public class XsdDataContractExporter
type XsdDataContractExporter = class
Public Class XsdDataContractExporter
Herança
XsdDataContractExporter

Exemplos

O exemplo a XsdDataContractExporter seguir cria uma instância do método e chama o Export(Type) método.

using System;
using System.Xml;
using System.Runtime.Serialization;
using System.Xml.Schema;

public class Program
{
    public static void Main()
    {
        try
        {
            ExportXSD();
        }
        catch (Exception exc)
        {
            Console.WriteLine("Message: {0} StackTrace:{1}", exc.Message, exc.StackTrace);
        }
        finally
        {
            Console.ReadLine();
        }
    }

    static void ExportXSD()
    {
        XsdDataContractExporter exporter = new XsdDataContractExporter();
        if (exporter.CanExport(typeof(Employee)))
        {
            exporter.Export(typeof(Employee));
            Console.WriteLine("number of schemas: {0}", exporter.Schemas.Count);
            Console.WriteLine();
            XmlSchemaSet mySchemas = exporter.Schemas;

            XmlQualifiedName XmlNameValue = exporter.GetRootElementName(typeof(Employee));
            string EmployeeNameSpace = XmlNameValue.Namespace;

            foreach (XmlSchema schema in mySchemas.Schemas(EmployeeNameSpace))
            {
                schema.Write(Console.Out);
            }
        }
    }

    static void GetXmlElementName()
    {
        XsdDataContractExporter myExporter = new XsdDataContractExporter();
        XmlQualifiedName xmlElementName =myExporter.GetRootElementName(typeof(Employee));
        Console.WriteLine("Namespace: {0}", xmlElementName.Namespace);
        Console.WriteLine("Name: {0}", xmlElementName.Name);
        Console.WriteLine("IsEmpty: {0}", xmlElementName.IsEmpty);
    }

    [DataContract(Namespace = "www.Contoso.com/Examples/")]
    public class Employee
    {
        [DataMember]
        public string EmployeeName;
        [DataMember]
        private string ID;
    }
}
Imports System.Collections
Imports System.Xml
Imports System.Runtime.Serialization
Imports System.Xml.Schema

Public Class Program
    Public Shared Sub Main() 
        Try
            ExportXSD()
        Catch exc As Exception
            Console.WriteLine("Message: {0} StackTrace:{1}", exc.Message, exc.StackTrace)
        Finally
            Console.ReadLine()
        End Try
    
    End Sub 
    
    
    Shared Sub ExportXSD() 

        Dim exporter As New XsdDataContractExporter()

        ' Use the ExportOptions to add the Possessions type to the 
        ' collection of KnownTypes. 
        Dim eOptions As New ExportOptions()
        eOptions.KnownTypes.Add(GetType(Possessions))        
        exporter.Options = eOptions

        If exporter.CanExport(GetType(Employee)) Then
            exporter.Export(GetType(Employee))
            Console.WriteLine("number of schemas: {0}", exporter.Schemas.Count)
            Console.WriteLine()
            Dim mySchemas As XmlSchemaSet = exporter.Schemas
            
            Dim XmlNameValue As XmlQualifiedName = _
               exporter.GetRootElementName(GetType(Employee))
            Dim EmployeeNameSpace As String = XmlNameValue.Namespace
            
            Dim schema As XmlSchema
            For Each schema In  mySchemas.Schemas(EmployeeNameSpace)
                schema.Write(Console.Out)
            Next schema
        End If
    
    End Sub 
    
    
    Shared Sub GetXmlElementName() 
        Dim myExporter As New XsdDataContractExporter()
        Dim xmlElementName As XmlQualifiedName = myExporter. _
            GetRootElementName(GetType(Employee))
        Console.WriteLine("Namespace: {0}", xmlElementName.Namespace)
        Console.WriteLine("Name: {0}", xmlElementName.Name)
        Console.WriteLine("IsEmpty: {0}", xmlElementName.IsEmpty)
    
    End Sub 
    
    <DataContract([Namespace] := "www.Contoso.com/Examples/")>  _
    Public Class Employee

        <DataMember()>  _
        Public EmployeeName As String
        <DataMember()>  _
        Private ID As String
        ' This member may return a Possessions type.
        <DataMember> _
        public Miscellaneous As Hashtable 

    End Class 

    <DataContract> _
    Public Class Possessions

        <DataMember> _
        Public ItemName As String
    End Class

End Class

Comentários

Use a XsdDataContractExporter classe quando você tiver criado um serviço Web que incorpore dados representados por tipos CLR (Common Language Runtime) e quando precisar exportar esquemas XML para cada tipo a ser consumido por outros serviços Web. Ou seja, XsdDataContractExporter transforma um conjunto de tipos CLR em esquemas XML. (Para obter mais informações sobre os tipos que podem ser usados, consulte Tipos compatíveis com o Serializador de Contrato de Dados.) Em seguida, os esquemas podem ser expostos por meio de um documento WSDL (Linguagem de Descrição dos Serviços Web) para uso por outras pessoas que precisam interoperar com seu serviço.

Por outro lado, se você estiver criando um serviço Web que deve interoperar com um serviço Web existente, use o XsdDataContractImporter para transformar esquemas XML e criar os tipos CLR que representam os dados em uma linguagem de programação selecionada.

O XsdDataContractExporter gera um XmlSchemaSet objeto que contém a coleção de esquemas. Acesse o conjunto de esquemas por meio da Schemas() propriedade.

Note

Para gerar rapidamente arquivos XSD (definição de esquema XML) que outros serviços Web podem consumir, use o XsdDataContractExporter.

Exportar esquemas para um XmlSchemaSet

Para criar uma instância da XmlSchemaSet classe que contém arquivos de esquema XML, você deve estar ciente do seguinte.

O conjunto de tipos que você está exportando é registrado como um conjunto interno de contratos de dados. Portanto, você pode chamar o CanExport método várias vezes para adicionar novos tipos ao conjunto de esquemas sem degradar o desempenho, pois somente os novos tipos serão adicionados ao conjunto. Durante a Export operação, os esquemas existentes são comparados com os novos esquemas que estão sendo adicionados. Se houver conflitos, uma exceção será lançada. Um conflito geralmente é detectado se dois tipos, com o mesmo nome de contrato de dados, mas com contratos diferentes (e diferentes membros), forem exportados pela mesma instância XsdDataContractExporter.

Utilize o exportador

Uma maneira recomendada de usar essa classe é a seguinte:

  1. Use uma das CanExport sobrecargas para determinar se o tipo ou conjunto de tipos especificado pode ser exportado. Utilize uma das sobrecargas apropriadas à sua necessidade.

  2. Chame o método correspondente Export .

  3. Recupere os esquemas da propriedade Schemas.

Construtores

Nome Description
XsdDataContractExporter()

Inicializa uma nova instância da classe XsdDataContractExporter.

XsdDataContractExporter(XmlSchemaSet)

Inicializa uma nova instância da XsdDataContractExporter classe com o conjunto de esquemas especificado.

Propriedades

Nome Description
Options

Obtém ou define um ExportOptions que contém opções que podem ser definidas para a operação de exportação.

Schemas

Obtém a coleção de esquemas XML exportados.

Métodos

Nome Description
CanExport(ICollection<Assembly>)

Obtém um valor que indica se o conjunto de tipos CLR (.common language runtime) contidos em um conjunto de assemblies pode ser exportado.

CanExport(ICollection<Type>)

Obtém um valor que indica se o conjunto de tipos CLR (.common language runtime) contidos em um ICollection<T> pode ser exportado.

CanExport(Type)

Obtém um valor que indica se o tipo CLR (Common Language Runtime) especificado pode ser exportado.

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
Export(ICollection<Assembly>)

Transforma os tipos contidos na coleção especificada de assemblies.

Export(ICollection<Type>)

Transforma os tipos contidos no ICollection<T> método passado.

Export(Type)

Transforma o tipo .NET especificado em um esquema XSD (linguagem de definição de esquema XML).

GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetRootElementName(Type)

Retorna o nome e o namespace de nível superior para o Type.

GetSchemaType(Type)

Retorna o tipo de esquema XML para o tipo especificado.

GetSchemaTypeName(Type)

Retorna o nome do contrato e o namespace de contrato para o Type.

GetType()

Obtém o Type da instância atual.

(Herdado de Object)
MemberwiseClone()

Cria uma cópia superficial do Objectatual.

(Herdado de Object)
ToString()

Retorna uma cadeia de caracteres que representa o objeto atual.

(Herdado de Object)

Aplica-se a

Confira também