SoapFormatter Clase
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Serializa y deserializa un objeto, o un gráfico completo de objetos conectados, en formato SOAP.
public ref class SoapFormatter sealed : System::Runtime::Remoting::Messaging::IRemotingFormatter
public sealed class SoapFormatter : System.Runtime.Remoting.Messaging.IRemotingFormatter
type SoapFormatter = class
interface IRemotingFormatter
interface IFormatter
Public NotInheritable Class SoapFormatter
Implements IRemotingFormatter
- Herencia
-
SoapFormatter
- Implementaciones
Ejemplos
#using <system.dll>
#using <system.runtime.serialization.formatters.soap.dll>
using namespace System;
using namespace System::IO;
using namespace System::Collections;
using namespace System::Runtime::Serialization;
using namespace System::Runtime::Serialization::Formatters::Soap;
void Serialize()
{
// Create a hashtable of values that will eventually be serialized.
Hashtable^ addresses = gcnew 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 keys/values),
// you must first open a stream for writing.
// We will use a file stream here.
FileStream^ fs = gcnew FileStream( "DataFile.soap",FileMode::Create );
// Construct a SoapFormatter and use it
// to serialize the data to the stream.
SoapFormatter^ formatter = gcnew SoapFormatter;
try
{
formatter->Serialize( fs, addresses );
}
catch ( SerializationException^ e )
{
Console::WriteLine( "Failed to serialize. Reason: {0}", e->Message );
throw;
}
finally
{
fs->Close();
}
}
void Deserialize()
{
// Declare the hashtable reference.
Hashtable^ addresses = nullptr;
// Open the file containing the data that we want to deserialize.
FileStream^ fs = gcnew FileStream( "DataFile.soap",FileMode::Open );
try
{
SoapFormatter^ formatter = gcnew SoapFormatter;
// Deserialize the hashtable from the file and
// assign the reference to our local variable.
addresses = dynamic_cast<Hashtable^>(formatter->Deserialize( fs ));
}
catch ( SerializationException^ e )
{
Console::WriteLine( "Failed to deserialize. Reason: {0}", e->Message );
throw;
}
finally
{
fs->Close();
}
// To prove that the table deserialized correctly,
// display the keys/values to the console.
IEnumerator^ myEnum = addresses->GetEnumerator();
while ( myEnum->MoveNext() )
{
DictionaryEntry^ de = safe_cast<DictionaryEntry^>(myEnum->Current);
Console::WriteLine( " {0} lives at {1}.", de->Key, de->Value );
}
}
[STAThread]
int main()
{
Serialize();
Deserialize();
}
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);
}
}
}
Imports System.IO
Imports System.Collections
Imports System.Runtime.Serialization
' Note: When building this code, you must reference the
' System.Runtime.Serialization.Formatters.Soap.dll assembly.
Imports System.Runtime.Serialization.Formatters.Soap
Module App
Sub Main()
Serialize()
Deserialize()
End Sub
Sub Serialize()
' Create a hashtable of values that will eventually be serialized.
Dim addresses As 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.
Dim fs As New FileStream("DataFile.soap", FileMode.Create)
' Construct a SoapFormatter and use it
' to serialize the data to the stream.
Dim formatter As New SoapFormatter
Try
formatter.Serialize(fs, addresses)
Catch e As SerializationException
Console.WriteLine("Failed to serialize. Reason: " & e.Message)
Throw
Finally
fs.Close()
End Try
End Sub
Sub Deserialize()
' Declare the hashtable reference.
Dim addresses As Hashtable = Nothing
' Open the file containing the data that you want to deserialize.
Dim fs As New FileStream("DataFile.soap", FileMode.Open)
Try
Dim formatter As New SoapFormatter
' Deserialize the hashtable from the file and
' assign the reference to the local variable.
addresses = DirectCast(formatter.Deserialize(fs), Hashtable)
Catch e As SerializationException
Console.WriteLine("Failed to deserialize. Reason: " & e.Message)
Throw
Finally
fs.Close()
End Try
' To prove that the table deserialized correctly,
' display the key/value pairs to the console.
Dim de As DictionaryEntry
For Each de In addresses
Console.WriteLine("{0} lives at {1}.", de.Key, de.Value)
Next
End Sub
End Module
Comentarios
Note
Esta clase está obsoleta.
Advertencia
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 RPCs 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 gráfico 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 una RPC sin usar la IRemotingFormatter funcionalidad, coloque un objeto que admita la ISoapMessage interfaz en la raíz de un grafo que se va a serializar. 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 el estándar "Alternativo" iso 8601: 1998, sección 5.5.3.2.1.
Constructores
| Nombre | Description |
|---|---|
| SoapFormatter() |
Inicializa una nueva instancia de la SoapFormatter clase con valores de propiedad predeterminados. |
| SoapFormatter(ISurrogateSelector, StreamingContext) |
Inicializa una nueva instancia de la SoapFormatter clase con los valores especificados ISurrogateSelector y StreamingContext. |
Propiedades
| Nombre | Description |
|---|---|
| AssemblyFormat |
Obtiene o establece el comportamiento del deserializador con respecto a la búsqueda y carga de ensamblados. |
| Binder |
Obtiene o establece el SerializationBinder objeto que controla el enlace de un objeto serializado a un tipo. |
| Context |
Obtiene o establece el StreamingContext objeto usado con este SoapFormatterobjeto . |
| FilterLevel |
Obtiene o establece el TypeFilterLevel de deserialización automática para la comunicación remota de .NET Framework. |
| SurrogateSelector |
Obtiene o establece el objeto que controla la sustitución de tipos durante la SurrogateSelector serialización y deserialización. |
| TopObject |
Obtiene o establece el objeto ISoapMessage en el que se deserializa el objeto superior SOAP. |
| TypeFormat |
Obtiene o establece el formato en el que se establecen las descripciones de tipo en la secuencia serializada. |
Métodos
| Nombre | Description |
|---|---|
| Deserialize(Stream, HeaderHandler) |
Deserializa la secuencia en un gráfico de objetos con los encabezados de esa secuencia que controla el objeto especificado HeaderHandler. |
| Deserialize(Stream) |
Deserializa los datos de la secuencia proporcionada y reconstituye el gráfico de objetos. |
| Equals(Object) |
Determina si el objeto especificado es igual al objeto actual. (Heredado de Object) |
| GetHashCode() |
Actúa 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 Objectactual. (Heredado de Object) |
| Serialize(Stream, Object, Header[]) |
Serializa un objeto o gráfico de objetos con la raíz especificada a la especificada Stream en el formato SOAP Remote Procedure Call (RPC). |
| Serialize(Stream, Object) |
Serializa un objeto o gráfico de objetos con la raíz especificada en el especificado Stream. |
| ToString() |
Devuelve una cadena que representa el objeto actual. (Heredado de Object) |