Exportar (0) Imprimir
Expandir todo
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

AspNetCompatibilityRequirementsAttribute (Clase)

Aplicado a un servicio Windows Communication Foundation (WCF) para indicar si ese servicio se puede ejecutar en código de compatibilidad ASP.NET.

System.Object
  System.Attribute
    System.ServiceModel.Activation.AspNetCompatibilityRequirementsAttribute

Espacio de nombres:  System.ServiceModel.Activation
Ensamblado:  System.ServiceModel (en System.ServiceModel.dll)

[AttributeUsageAttribute(AttributeTargets.Class)]
public sealed class AspNetCompatibilityRequirementsAttribute : Attribute, 
	IServiceBehavior

El tipo AspNetCompatibilityRequirementsAttribute expone los siguientes miembros.

  NombreDescripción
Método públicoAspNetCompatibilityRequirementsAttributeInicializa una nueva instancia de la clase AspNetCompatibilityRequirementsAttribute.
Arriba

  NombreDescripción
Propiedad públicaRequirementsModeObtiene o establece el nivel de compatibilidad ASP.NET requerido por el servicio.
Propiedad públicaTypeIdCuando se implementa en una clase derivada, obtiene un identificador único para este Attribute. (Se hereda de Attribute).
Arriba

  NombreDescripción
Método públicoEqualsInfraestructura. Devuelve un valor que indica si esta instancia equivale al objeto especificado. (Se hereda de Attribute).
Método públicoGetHashCodeDevuelve el código hash de esta instancia. (Se hereda de Attribute).
Método públicoGetType Obtiene el Type de la instancia actual. (Se hereda de Object).
Método públicoIsDefaultAttributeCuando se invalida en una clase derivada, indica si el valor de esta instancia es el valor predeterminado para la clase derivada. (Se hereda de Attribute).
Método públicoMatch Cuando se invalida en una clase derivada, devuelve un valor que indica si esta instancia es igual al objeto especificado. (Se hereda de Attribute).
Método públicoToString Retorna una cadena que representa al objeto actual. (Se hereda de Object).
Arriba

  NombreDescripción
Implementación explícita de interfacesMétodo privado_Attribute.GetIDsOfNamesAsigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoObtiene la información de tipos de un objeto, que puede utilizarse para obtener la información de tipos de una interfaz. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoCount

Recupera el número de interfaces de tipo de información que suministra un objeto (0 ó 1)

(Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.InvokeProporciona acceso a las propiedades y los métodos expuestos por un objeto. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privadoIServiceBehavior.AddBindingParametersAgrega los datos personalizados a los que pueden tener acceso los elementos de enlace para admitir la implementación del contrato.
Implementación explícita de interfacesMétodo privadoIServiceBehavior.ApplyDispatchBehaviorComprueba que el tipo de hospedaje es coherente con los requisitos de compatibilidad de ASP.NET.
Implementación explícita de interfacesMétodo privadoIServiceBehavior.ValidateValida el comportamiento del servicio.
Arriba

Cuando se aplica a una clase de implementación de servicio, este atributo indica si este servicio requiere o admite el modo de compatibilidad ASP.NET que se va habilitar para el dominio de aplicación del hospedaje (AppDomain).

Los servicios WCF de hospedaje AppDomain se pueden ejecutar en dos modos de hospedaje diferentes:

  • Modo de transporte mixto (Valor predeterminado): en este modo, los servicios WCF no participan en la canalización HTTP ASP.NET. Esto garantiza que un servicio WCF se comporte de forma consistente, independientemente del entorno y del transporte de hospedaje.

  • Modo de compatibilidad de ASP.NET: en este modo, los servicios de WCF participan en la canalización HTTP de ASP.NET de una manera similar a los servicios ASMX. Las características de ASP.NET como Autorización de archivo, Autorización URL y Estado sesión HTTP son aplicables a los servicios de WCF que se ejecutan en este modo.

La marca de configuración en el nivel de la aplicación aspNetCompatibilityEnabled controla el modo de hospedaje.

<system.serviceModel>

<serviceHostingEnvironment aspNetCompatibilityEnabled="true"/>

</system.serviceModel>

Esta marca es false de forma predeterminada. De ese modo, los servicios WCF se ejecutan en el Modo de transporte mixto a menos que opte explícitamente por el modo de compatibilidad ASP.NET.

el modo de compatibilidad dePara obtener más información sobreASP.NET , vea <serviceHostingEnvironment>.

Utilice la propiedad RequirementsMode para hacerlo. En el tiempo de ejecución, las aplicaciones pueden detectar si el modo de compatibilidad ASP.NET está habilitado comprobando el valor de la propiedad AspNetCompatibilityEnabled estática.

Los programadores del servicio pueden asegurarse de que el servicio se ejecutará únicamente en modo de compatibilidad de ASP.NET estableciendo la propiedad de RequirementsMode en AspNetCompatibilityRequirementsAttribute a Required tal y como se muestra en el ejemplo siguiente


<ServiceContract(Namespace:="http://Microsoft.ServiceModel.Samples")> _
Public Interface ICalculatorSession

    <OperationContract()> _
    Sub Clear()
    <OperationContract()> _
    Sub AddTo(ByVal n As Double)
    <OperationContract()> _
    Sub SubtractFrom(ByVal n As Double)
    <OperationContract()> _
    Sub MultiplyBy(ByVal n As Double)
    <OperationContract()> _
    Sub DivideBy(ByVal n As Double)
    <OperationContract()> _
    Function Equal() As Double
End Interface



[ServiceContract(Namespace="http://Microsoft.ServiceModel.Samples")]
public interface ICalculatorSession
{
    [OperationContract]
    void Clear();
    [OperationContract]
    void AddTo(double n);
    [OperationContract]
    void SubtractFrom(double n);
    [OperationContract]
    void MultiplyBy(double n);
    [OperationContract]
    void DivideBy(double n);
    [OperationContract]
    double Equals();
}



    <AspNetCompatibilityRequirements(RequirementsMode:=AspNetCompatibilityRequirementsMode.Required)> _
    Public Class CalculatorService
        Implements ICalculatorSession

        Property Result() As Double
            ' Store result in AspNet Session.
            Get
                If (HttpContext.Current.Session("Result") Is Nothing) Then
                    Return 0D
                End If
                Return HttpContext.Current.Session("Result")
            End Get
            Set(ByVal value As Double)
                HttpContext.Current.Session("Result") = value
            End Set
        End Property

        Public Sub Clear() _
 Implements ICalculatorSession.Clear
            Result = 0D
        End Sub

        Public Sub AddTo(ByVal n As Double) _
Implements ICalculatorSession.AddTo
            Result += n
        End Sub

        Public Sub SubtractFrom(ByVal n As Double) _
Implements ICalculatorSession.SubtractFrom

            Result -= n
        End Sub

        Public Sub MultiplyBy(ByVal n As Double) _
Implements ICalculatorSession.MultiplyBy

            Result *= n
        End Sub

        Public Sub DivideBy(ByVal n As Double) _
Implements ICalculatorSession.DivideBy

            Result /= n
        End Sub

        Public Function Equal() As Double _
Implements ICalculatorSession.Equal

            Return Result
        End Function
    End Class



[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Required)]
public class CalculatorService : ICalculatorSession
{
    double result
    {   // Store result in AspNet session.
        get
        {
            if (HttpContext.Current.Session["Result"] != null)
                return (double)HttpContext.Current.Session["Result"];
            return 0.0D;
        }
        set
        {
            HttpContext.Current.Session["Result"] = value;
        }
    }

    public void Clear()
    {

    }

    public void AddTo(double n)
    {
        result += n;
    }

    public void SubtractFrom(double n)
    {
        result -= n;
    }

    public void MultiplyBy(double n)
    {
        result *= n;
    }

    public void DivideBy(double n)
    {
        result /= n;
    }

    public double Equals()
    {
        return result;
    }
}


.NET Framework

Compatible con: 4.5.2, 4.5.1, 4.5, 4, 3.5, 3.0

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (no se admite el rol Server Core), Windows Server 2008 R2 (se admite el rol Server Core con SP1 o versiones posteriores; no se admite Itanium)

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Todos los miembros static (Shared en Visual Basic) públicos de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft