Ler en inglés

Compartir por


HostSecurityManager.DetermineApplicationTrust Método

Definición

Determina si se debe ejecutar una aplicación.

C#
public virtual System.Security.Policy.ApplicationTrust DetermineApplicationTrust(System.Security.Policy.Evidence applicationEvidence, System.Security.Policy.Evidence activatorEvidence, System.Security.Policy.TrustManagerContext context);
C#
[System.Security.SecurityCritical]
public virtual System.Security.Policy.ApplicationTrust DetermineApplicationTrust(System.Security.Policy.Evidence applicationEvidence, System.Security.Policy.Evidence activatorEvidence, System.Security.Policy.TrustManagerContext context);

Parámetros

applicationEvidence
Evidence

Evidencia para la aplicación que se va a activar.

activatorEvidence
Evidence

Opcionalmente, evidencia para el dominio de aplicación que realiza la activación.

context
TrustManagerContext

Contexto de confianza.

Devoluciones

Objeto que contiene información de confianza sobre la aplicación.

Atributos

Excepciones

applicationEvidence es null.

No se pudo encontrar un objeto ActivationArguments en la evidencia de la aplicación.

o bien

La propiedad ActivationContext de los argumentos de activación es null.

El conjunto de permisos ApplicationTrust concedido no contiene el conjunto de solicitudes mínimo especificado por ActivationContext.

Ejemplos

En el ejemplo siguiente se muestra cómo invalidar el DetermineApplicationTrust método para un administrador de seguridad de host personalizado. Este ejemplo forma parte de un ejemplo más grande proporcionado para la HostSecurityManager clase .

C#
[SecurityPermissionAttribute(SecurityAction.Demand, Execution = true)]
[SecurityPermissionAttribute(SecurityAction.Assert, Unrestricted = true)]
public override ApplicationTrust DetermineApplicationTrust(Evidence applicationEvidence, Evidence activatorEvidence, TrustManagerContext context)
{
    if (applicationEvidence == null)
        throw new ArgumentNullException("applicationEvidence");

    // Get the activation context from the application evidence.
    // This HostSecurityManager does not examine the activator evidence
    // nor is it concerned with the TrustManagerContext;
    // it simply grants the requested grant in the application manifest.

    IEnumerator enumerator = applicationEvidence.GetHostEnumerator();
    ActivationArguments activationArgs = null;
    while (enumerator.MoveNext())
    {
        activationArgs = enumerator.Current as ActivationArguments;
        if (activationArgs != null)
            break;
    }

    if (activationArgs == null)
        return null;

    ActivationContext activationContext = activationArgs.ActivationContext;
    if (activationContext == null)
        return null;

    ApplicationTrust trust = new ApplicationTrust(activationContext.Identity);
    ApplicationSecurityInfo asi = new ApplicationSecurityInfo(activationContext);
    trust.DefaultGrantSet = new PolicyStatement(asi.DefaultRequestSet, PolicyStatementAttribute.Nothing);
    trust.IsApplicationTrustedToRun = true;
    return trust;
}

Comentarios

Este método se puede invalidar mediante una clase derivada. La implementación base llama al administrador de seguridad de aplicaciones para determinar si se debe ejecutar la aplicación.

La implementación base no usa la evidencia activator. Sin embargo, una implementación invalidada podría usar la evidencia del activador para determinar la evidencia de seguridad para el dominio de aplicación que intenta activar la aplicación.

Se aplica a

Produto Versións
.NET 8 (package-provided), 9 (package-provided), 10 (package-provided)
.NET Framework 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
.NET Standard 2.0 (package-provided)
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10