CommunicationException 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í.
Representa un error de comunicación en el servicio o aplicación cliente.
public ref class CommunicationException : Exception
public ref class CommunicationException : SystemException
public class CommunicationException : Exception
[System.Serializable]
public class CommunicationException : SystemException
type CommunicationException = class
inherit Exception
[<System.Serializable>]
type CommunicationException = class
inherit SystemException
Public Class CommunicationException
Inherits Exception
Public Class CommunicationException
Inherits SystemException
- Herencia
- Herencia
- Derivado
- Atributos
Ejemplos
En el siguiente ejemplo de código se muestra un cliente que gestiona los tipos de CommunicationException. Este cliente también gestiona los objetos FaultException porque se ha definido IncludeExceptionDetailInFaults en true
en el servicio.
using System;
using System.ServiceModel;
using System.ServiceModel.Channels;
using Microsoft.WCF.Documentation;
public class Client
{
public static void Main()
{
// Picks up configuration from the configuration file.
SampleServiceClient wcfClient = new SampleServiceClient();
try
{
// Making calls.
Console.WriteLine("Enter the greeting to send: ");
string greeting = Console.ReadLine();
Console.WriteLine("The service responded: " + wcfClient.SampleMethod(greeting));
Console.WriteLine("Press ENTER to exit:");
Console.ReadLine();
}
catch (TimeoutException timeProblem)
{
Console.WriteLine("The service operation timed out. " + timeProblem.Message);
wcfClient.Abort();
Console.ReadLine();
}
// Catch the contractually specified SOAP fault raised here as an exception.
catch (FaultException<GreetingFault> greetingFault)
{
Console.WriteLine(greetingFault.Detail.Message);
Console.Read();
wcfClient.Abort();
}
// Catch unrecognized faults. This handler receives exceptions thrown by WCF
// services when ServiceDebugBehavior.IncludeExceptionDetailInFaults
// is set to true.
catch (FaultException faultEx)
{
Console.WriteLine("An unknown exception was received. "
+ faultEx.Message
+ faultEx.StackTrace
);
Console.Read();
wcfClient.Abort();
}
// Standard communication fault handler.
catch (CommunicationException commProblem)
{
Console.WriteLine("There was a communication problem. " + commProblem.Message + commProblem.StackTrace);
Console.Read();
wcfClient.Abort();
}
}
}
Imports System.ServiceModel
Imports System.ServiceModel.Channels
Imports Microsoft.WCF.Documentation
Public Class Client
Public Shared Sub Main()
' Picks up configuration from the configuration file.
Dim wcfClient As New SampleServiceClient()
Try
' Making calls.
Console.WriteLine("Enter the greeting to send: ")
Dim greeting As String = Console.ReadLine()
Console.WriteLine("The service responded: " & wcfClient.SampleMethod(greeting))
Console.WriteLine("Press ENTER to exit:")
Console.ReadLine()
Catch timeProblem As TimeoutException
Console.WriteLine("The service operation timed out. " & timeProblem.Message)
wcfClient.Abort()
Console.ReadLine()
' Catch the contractually specified SOAP fault raised here as an exception.
Catch greetingFault As FaultException(Of GreetingFault)
Console.WriteLine(greetingFault.Detail.Message)
Console.Read()
wcfClient.Abort()
' Catch unrecognized faults. This handler receives exceptions thrown by WCF
' services when ServiceDebugBehavior.IncludeExceptionDetailInFaults
' is set to true.
Catch faultEx As FaultException
Console.WriteLine("An unknown exception was received. " & faultEx.Message + faultEx.StackTrace)
Console.Read()
wcfClient.Abort()
' Standard communication fault handler.
Catch commProblem As CommunicationException
Console.WriteLine("There was a communication problem. " & commProblem.Message + commProblem.StackTrace)
Console.Read()
wcfClient.Abort()
End Try
End Sub
End Class
Comentarios
Las aplicaciones sólidas de cliente y servicio Windows Communication Foundation (WCF) controlan CommunicationException los objetos que se pueden producir durante la comunicación. Además, existen dos tipos de excepción derivadas de CommunicationException (FaultException<TDetail> y FaultException) que los clientes también esperan a menudo. Por consiguiente, para evitar que el controlador CommunicationException genérico detecte los tipos de excepción más concretos, detecte estas excepciones antes de administrar CommunicationException.
- FaultException<TDetail> Los objetos se inician en el cliente cuando se recibe un error soap especificado en el contrato de operación en respuesta a una operación bidireccional (es decir, un método con un OperationContractAttribute atributo con IsOneWay establecido en
false
).
FaultException Los objetos se inician cuando un agente de escucha recibe un error soap que no se espera o se especifica en el contrato de operación. Esto ocurre normalmente cuando se depuran las aplicaciones y el servicio tiene la propiedad IncludeExceptionDetailInFaults establecida en true
.
Nota
Al implementar canales personalizados y elementos de enlace, se recomienda encarecidamente que sus componentes sólo inicien System.TimeoutException u objetos derivados de CommunicationException. En los casos en los que los componentes inician una excepción recuperable específica de un componente, encapsúlela dentro de un objeto CommunicationException.
Para obtener más información sobre el diseño y el uso del sistema de errores de WCF, vea Especificar y controlar errores en contratos y servicios.
Importante
El tiempo de ejecución de WCF no producirá un CommunicationException que no sea seguro para controlar en el punto en el que sale del tiempo de ejecución de WCF y escribe el código de usuario.
Constructores
CommunicationException() |
Inicializa una nueva instancia de la clase CommunicationException. |
CommunicationException(SerializationInfo, StreamingContext) |
Inicializa una nueva instancia de la clase CommunicationException con la información de serialización y los objetos de contexto especificados. |
CommunicationException(String) |
Inicializa una nueva instancia de la clase CommunicationException utilizando el mensaje especificado. |
CommunicationException(String, Exception) |
Inicializa una nueva instancia de la clase CommunicationException con el mensaje y la excepción interna especificados. |
Propiedades
Data |
Obtiene una colección de pares clave/valor que proporciona información definida por el usuario adicional sobre la excepción. (Heredado de Exception) |
HelpLink |
Obtiene o establece un vínculo al archivo de ayuda asociado a esta excepción. (Heredado de Exception) |
HResult |
Obtiene o establece HRESULT, un valor numérico codificado que se asigna a una excepción específica. (Heredado de Exception) |
InnerException |
Obtiene la instancia Exception que produjo la excepción actual. (Heredado de Exception) |
Message |
Obtiene un mensaje que describe la excepción actual. (Heredado de Exception) |
Source |
Devuelve o establece el nombre de la aplicación o del objeto que generó el error. (Heredado de Exception) |
StackTrace |
Obtiene una representación de cadena de los marcos inmediatos en la pila de llamadas. (Heredado de Exception) |
TargetSite |
Obtiene el método que produjo la excepción actual. (Heredado de Exception) |
Métodos
Equals(Object) |
Determina si el objeto especificado es igual que el objeto actual. (Heredado de Object) |
GetBaseException() |
Cuando se invalida en una clase derivada, devuelve la clase Exception que representa la causa principal de una o más excepciones posteriores. (Heredado de Exception) |
GetHashCode() |
Sirve como la función hash predeterminada. (Heredado de Object) |
GetObjectData(SerializationInfo, StreamingContext) |
Cuando se invalida en una clase derivada, establece SerializationInfo con información sobre la excepción. (Heredado de Exception) |
GetType() |
Obtiene el tipo de tiempo de ejecución de la instancia actual. (Heredado de Exception) |
MemberwiseClone() |
Crea una copia superficial del Object actual. (Heredado de Object) |
ToString() |
Crea y devuelve una representación de cadena de la excepción actual. (Heredado de Exception) |
Eventos
SerializeObjectState |
Obsoleto.
Ocurre cuando una excepción se serializa para crear un objeto de estado de excepción que contenga datos serializados sobre la excepción. (Heredado de Exception) |