Este artigo foi traduzido por máquina. Para visualizar o arquivo em inglês, marque a caixa de seleção Inglês. Você também pode exibir o texto Em inglês em uma janela pop-up, movendo o ponteiro do mouse sobre o texto.
Tradução
Inglês

Classe SoapFormatter

 

Serializa e desserializa um objeto ou um gráfico inteiro de objetos conectados, em formato SOAP.

Namespace:   System.Runtime.Serialization.Formatters.Soap
Assembly:  System.Runtime.Serialization.Formatters.Soap (em System.Runtime.Serialization.Formatters.Soap.dll)

System.Object
  System.Runtime.Serialization.Formatters.Soap.SoapFormatter

public sealed class SoapFormatter : IRemotingFormatter, IFormatter

NomeDescrição
System_CAPS_pubmethodSoapFormatter()

Inicializa uma nova instância de SoapFormatter classe com valores de propriedade padrão.

System_CAPS_pubmethodSoapFormatter(ISurrogateSelector, StreamingContext)

Inicializa uma nova instância de SoapFormatter classe com especificado ISurrogateSelector e StreamingContext.

NomeDescrição
System_CAPS_pubpropertyAssemblyFormat

Obtém ou define o comportamento do desserializador com relação a encontrar e carregar assemblies.

System_CAPS_pubpropertyBinder

Obtém ou define o SerializationBinder que controla a associação de um objeto serializado a um tipo.

System_CAPS_pubpropertyContext

Obtém ou define o StreamingContext usado com este SoapFormatter.

System_CAPS_pubpropertyFilterLevel

Obtém ou define o TypeFilterLevel de desserialização automática para comunicação remota do .NET Framework.

System_CAPS_pubpropertySurrogateSelector

Obtém ou define o SurrogateSelector que controles de tipo de substituição durante a serialização e desserialização.

System_CAPS_pubpropertyTopObject

Obtém ou define o ISoapMessage no qual o objeto superior SOAP é desserializado.

System_CAPS_pubpropertyTypeFormat

Obtém ou define o formato no qual descrições de tipo são dispostas no fluxo serializado.

NomeDescrição
System_CAPS_pubmethodDeserialize(Stream)

Desserializa os dados no fluxo fornecido e reconstitui o gráfico de objetos.

System_CAPS_pubmethodDeserialize(Stream, HeaderHandler)

Desserializa o fluxo em um gráfico de objeto com os cabeçalhos nesse fluxo manipulados pelo HeaderHandler especificado.

System_CAPS_pubmethodEquals(Object)

Verifica se o objeto especificado é igual ao objeto atual. (Herdado de Object.)

System_CAPS_pubmethodGetHashCode()

Serve como a função de hash padrão.(Herdado de Object.)

System_CAPS_pubmethodGetType()

Obtém o Type da instância atual.(Herdado de Object.)

System_CAPS_pubmethodSerialize(Stream, Object)

Serializa um objeto ou gráfico de objetos com a raiz especificada para o Stream especificado.

System_CAPS_pubmethodSerialize(Stream, Object, Header[])

Serializa um objeto ou um gráfico de objetos com a raiz especificado para o determinado Stream no formato SOAP procedimento remoto (RPC).

System_CAPS_pubmethodToString()

Retorna uma string que representa o objeto atual.(Herdado de Object.)

System_CAPS_noteObservação

Beginning with the .NET Framework 2.0, this class is obsolete. Use T:System.Runtime.Serialization.Formatters.Binary.BinaryFormatter instead.

The T:System.Runtime.Serialization.Formatters.Soap.SoapFormatter and T:System.Runtime.Serialization.Formatters.Binary.BinaryFormatter classes implement the T:System.Runtime.Remoting.Messaging.IRemotingFormatter interface to support remote procedure calls (RPCs), and the T:System.Runtime.Serialization.IFormatter interface (inherited by the T:System.Runtime.Remoting.Messaging.IRemotingFormatter) to support serialization of a graph of objects. The T:System.Runtime.Serialization.Formatters.Soap.SoapFormatter class also supports RPCs with T:System.Runtime.Serialization.Formatters.ISoapMessage objects, without using the T:System.Runtime.Remoting.Messaging.IRemotingFormatter functionality.

During RPCs, the T:System.Runtime.Remoting.Messaging.IRemotingFormatter interface allows the specification of two separate object graphs: the graph of objects to serialize, and an additional graph that contains an array of header objects that convey information about the remote function call (for example, transaction ID or a method signature). For proper serialization, the root object of the first graph must be an object that implements either the T:System.Runtime.Remoting.Messaging.IMethodCallMessage interface or the T:System.Runtime.Remoting.Messaging.IMethodReturnMessage interface.

During deserialization of an RPC, a T:System.Runtime.Remoting.Messaging.HeaderHandler delegate is specified to the M:System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(System.IO.Stream) method of the formatter. The remoting infrastructure uses the T:System.Runtime.Remoting.Messaging.HeaderHandler delegate to produce an object that supports the T:System.Runtime.Serialization.ISerializable interface. This object contains the information stored in the headers, and becomes the root of the graph returned by the deserializer.

The T:System.Runtime.Serialization.Formatters.Soap.SoapFormatter can also handle RPCs that are produced with objects that implement the T:System.Runtime.Serialization.Formatters.ISoapMessage interface. To create an RPC without using the T:System.Runtime.Remoting.Messaging.IRemotingFormatter functionality, place an object that supports the T:System.Runtime.Serialization.Formatters.ISoapMessage interface at the root of a graph being serialized. To deserialize an RPC created in this manner the P:System.Runtime.Serialization.Formatters.Soap.SoapFormatter.TopObject property must be set to another object that supports the T:System.Runtime.Serialization.Formatters.ISoapMessage interface, and contains the relevant remote call information.

TimeSpan objects are serialized according to the ISO 8601: 1998 section 5.5.3.2.1 "Alternative" standard.

The T:System.Runtime.Serialization.Formatters.Soap.SoapFormatter does not support serialization compatibility between versions of the .NET Framework. Serialization between versions 1.1 and 2.0 types in the Framework often fails. The following actions can be taken to remedy this issue:

  • Convert to use the T:System.Runtime.Serialization.Formatters.Binary.BinaryFormatter, which provides compatibility between 1.1 and 2.0.

  • Convert existing persisted data to the new format.

  • Convert all producers and consumers of serialized data to version 2.0.

  • Avoid using types that changed from 1.1 to 2.0.

using System;
using System.IO;
using System.Collections;
using System.Runtime.Serialization;

// Note: When building this code, you must reference the
// System.Runtime.Serialization.Formatters.Soap.dll assembly.
using System.Runtime.Serialization.Formatters.Soap;


class App 
{
    [STAThread]
    static void Main() 
    {
        Serialize();
        Deserialize();
    }

    static void Serialize() 
    {
        // Create a hashtable of values that will eventually be serialized.
        Hashtable addresses = new Hashtable();
        addresses.Add("Jeff", "123 Main Street, Redmond, WA 98052");
        addresses.Add("Fred", "987 Pine Road, Phila., PA 19116");
        addresses.Add("Mary", "PO Box 112233, Palo Alto, CA 94301");

        // To serialize the hashtable (and its key/value pairs), 
        // you must first open a stream for writing.
        // Use a file stream here.
        FileStream fs = new FileStream("DataFile.soap", FileMode.Create);

        // Construct a SoapFormatter and use it 
        // to serialize the data to the stream.
        SoapFormatter formatter = new SoapFormatter();
        try 
        {
            formatter.Serialize(fs, addresses);
        }
        catch (SerializationException e) 
        {
            Console.WriteLine("Failed to serialize. Reason: " + e.Message);
            throw;
        }
        finally 
        {
            fs.Close();
        }
    }


    static void Deserialize() 
    {
        // Declare the hashtable reference.
        Hashtable addresses  = null;

        // Open the file containing the data that you want to deserialize.
        FileStream fs = new FileStream("DataFile.soap", FileMode.Open);
        try 
        {
            SoapFormatter formatter = new SoapFormatter();

            // Deserialize the hashtable from the file and 
            // assign the reference to the local variable.
            addresses = (Hashtable) formatter.Deserialize(fs);
        }
        catch (SerializationException e) 
        {
            Console.WriteLine("Failed to deserialize. Reason: " + e.Message);
            throw;
        }
        finally 
        {
            fs.Close();
        }

        // To prove that the table deserialized correctly, 
        // display the key/value pairs to the console.
        foreach (DictionaryEntry de in addresses) 
        {
            Console.WriteLine("{0} lives at {1}.", de.Key, de.Value);
        }
    }
}

.NET Framework
Disponível desde 1.1

Quaisquer membros estáticos públicos ( Compartilhado no Visual Basic) desse tipo são thread-safe. Não há garantia de que qualquer membro de instância seja thread-safe.

Retornar ao início
Mostrar: