SoapFormatter Clase

Definición

Serializa o deserializa un objeto o todo un gráfico de objetos conectados, en formato SOAP.

C#
public sealed class SoapFormatter : System.Runtime.Remoting.Messaging.IRemotingFormatter
Herencia
SoapFormatter
Implementaciones

Ejemplos

C#
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);
        }
    }
}

Comentarios

Nota

A partir de .NET Framework 2.0, esta clase está obsoleta.

Aviso

BinaryFormatter no es seguro y no se puede convertir en seguro. Para obtener más información, vea Guía de seguridad de BinaryFormatter.

Las SoapFormatter clases y BinaryFormatter implementan la IRemotingFormatter interfaz para admitir llamadas a procedimientos remotos (RPC) y la IFormatter interfaz (heredada por ) IRemotingFormatterpara admitir la serialización de un gráfico de objetos. La SoapFormatter clase también admite RPC con ISoapMessage objetos, sin usar la IRemotingFormatter funcionalidad .

Durante los RPC, la IRemotingFormatter interfaz permite la especificación de dos gráficos de objetos independientes: el gráfico de objetos para serializar y un grafo adicional que contiene una matriz de objetos de encabezado que transmiten información sobre la llamada a función remota (por ejemplo, el identificador de transacción o una firma de método). Para la serialización adecuada, el objeto raíz del primer grafo debe ser un objeto que implemente la IMethodCallMessage interfaz o la IMethodReturnMessage interfaz.

Durante la deserialización de un RPC, se especifica un HeaderHandler delegado en el Deserialize método del formateador. La infraestructura de comunicación remota usa el HeaderHandler delegado para generar un objeto que admita la ISerializable interfaz. Este objeto contiene la información almacenada en los encabezados y se convierte en la raíz del gráfico devuelto por el deserializador.

SoapFormatter También puede controlar los RPC que se generan con objetos que implementan la ISoapMessage interfaz. Para crear un RPC sin usar la IRemotingFormatter funcionalidad, coloque un objeto que admita la ISoapMessage interfaz en la raíz de un grafo que se serializa. Para deserializar un RPC creado de esta manera, la TopObject propiedad debe establecerse en otro objeto que admita la ISoapMessage interfaz y contenga la información de llamada remota pertinente.

Los objetos TimeSpan se serializan según la norma ISO 8601: 1998 sección 5.5.3.2.1 "Alternativa".

Constructores

SoapFormatter()

Inicializa una nueva instancia de la clase SoapFormatter con los valores de propiedad predeterminados.

SoapFormatter(ISurrogateSelector, StreamingContext)

Inicializa una nueva instancia de la clase SoapFormatter con los parámetros ISurrogateSelector y StreamingContext especificados.

Propiedades

AssemblyFormat

Obtiene o establece el comportamiento del deserializador en lo que respecta a buscar y cargar ensamblados.

Binder

Obtiene o establece el SerializationBinder que controla el enlace entre un objeto serializado y un tipo.

Context

Obtiene o establece el StreamingContext utilizado con este SoapFormatter.

FilterLevel

Obtiene o establece la enumeración TypeFilterLevel de deserialización automática para la comunicación remota de .NET Framework.

SurrogateSelector

Obtiene o establece el SurrogateSelector que controla la sustitución de tipos durante el proceso de serialización y deserialización.

TopObject

Obtiene o establece ISoapMessage donde se deserializa el objeto SOAP superior.

TypeFormat

Obtiene o establece el formato en que se distribuyen las descripciones de tipos en la secuencia serializada.

Métodos

Deserialize(Stream)

Deserializa los datos de la secuencia suministrada y reconstituye el gráfico de objetos.

Deserialize(Stream, HeaderHandler)

Deserializa la secuencia a un gráfico de objetos; el HeaderHandler especificado se encarga de controlar los encabezados que aparecen en la secuencia.

Equals(Object)

Determina si el objeto especificado es igual que el objeto actual.

(Heredado de Object)
GetHashCode()

Sirve como la función hash predeterminada.

(Heredado de Object)
GetType()

Obtiene el Type de la instancia actual.

(Heredado de Object)
MemberwiseClone()

Crea una copia superficial del Object actual.

(Heredado de Object)
Serialize(Stream, Object)

Serializa un objeto o gráfico de objetos con el objeto superior (raíz) especificado al Stream indicado.

Serialize(Stream, Object, Header[])

Serializa un objeto o un gráfico de objetos con la raíz especificada en el Stream especificado en formato RPC (llamada a procedimiento remoto) SOAP.

ToString()

Devuelve una cadena que representa el objeto actual.

(Heredado de Object)

Se aplica a

Produto Versións
.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