Partager via


CodeConnectAccess Classe

Définition

Spécifie l'accès aux ressources réseau accordé au code.

public ref class CodeConnectAccess
public class CodeConnectAccess
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public class CodeConnectAccess
type CodeConnectAccess = class
[<System.Runtime.InteropServices.ComVisible(true)>]
[<System.Serializable>]
type CodeConnectAccess = class
Public Class CodeConnectAccess
Héritage
CodeConnectAccess
Attributs

Exemples

L’exemple de code suivant crée un NetCodeGroup objet et l’ajoute au niveau de stratégie Utilisateur.


static void SetNetCodeGroupAccess()
{
    String^ userPolicyLevel = "User";
    // Locate the User policy level.
    PolicyLevel^ level = nullptr;
    System::Collections::IEnumerator^ ph = 
        System::Security::SecurityManager::PolicyHierarchy();
    while(ph->MoveNext())
    {
        level = (PolicyLevel^)ph->Current;
        if (level->Label == userPolicyLevel)
        {
            break;       
        }
    }
    if (level->Label != userPolicyLevel)
        throw gcnew ApplicationException("Could not find User policy level.");

    IMembershipCondition^ membership =
        gcnew UrlMembershipCondition("http://www.contoso.com/*");
    NetCodeGroup^ codeGroup = gcnew NetCodeGroup(membership);
    // Delete default settings.
    codeGroup->ResetConnectAccess();
    // Create an object that represents access to the FTP scheme and 
    // default port.
    CodeConnectAccess^ CodeAccessFtp = 
        gcnew CodeConnectAccess(Uri::UriSchemeFtp, 
        CodeConnectAccess::DefaultPort);
    // Create an object that represents access to the HTTPS scheme 
    // and default port.
    CodeConnectAccess^ CodeAccessHttps = 
        gcnew CodeConnectAccess(Uri::UriSchemeHttps, 
        CodeConnectAccess::DefaultPort);
    // Create an object that represents access to the origin 
    // scheme and port.
    CodeConnectAccess^ CodeAccessOrigin = 
        CodeConnectAccess::CreateOriginSchemeAccess
        (CodeConnectAccess::OriginPort);
    // Add connection access objects to the NetCodeGroup object.
    codeGroup->AddConnectAccess(Uri::UriSchemeHttp, CodeAccessFtp);
    codeGroup->AddConnectAccess(Uri::UriSchemeHttp, CodeAccessHttps);
    codeGroup->AddConnectAccess(Uri::UriSchemeHttp, CodeAccessOrigin);
    // Provide name and description information for caspol.exe tool.
    codeGroup->Name = "ContosoHttpCodeGroup";
    codeGroup->Description = "Code originating from contoso.com can" +
        " connect back using the FTP or HTTPS.";
    // Add the code group to the User policy's root node.
    level->RootCodeGroup->AddChild(codeGroup);
    // Save the changes to the policy level.
    System::Security::SecurityManager::SavePolicy();
}
public static void SetNetCodeGroupAccess()
{
    const string userPolicyLevel = "User";
    // Locate the User policy level.
    PolicyLevel level = null;
    System.Collections.IEnumerator ph =
        System.Security.SecurityManager.PolicyHierarchy();
    while(ph.MoveNext())
    {
        level = (PolicyLevel)ph.Current;
        if( level.Label == userPolicyLevel )
        {
            break;
        }
    }
    if (level.Label != userPolicyLevel)
        throw new ApplicationException("Could not find User policy level.");

    IMembershipCondition membership =
        new UrlMembershipCondition(@"http://www.contoso.com/*");
    NetCodeGroup codeGroup = new NetCodeGroup(membership);
    // Delete default settings.
    codeGroup.ResetConnectAccess();
    // Create an object that represents access to the FTP scheme and default port.
    CodeConnectAccess a1 = new CodeConnectAccess(Uri.UriSchemeFtp, CodeConnectAccess.DefaultPort);
    // Create an object that represents access to the HTTPS scheme and default port.
    CodeConnectAccess a2 = new CodeConnectAccess(Uri.UriSchemeHttps, CodeConnectAccess.DefaultPort);
    // Create an object that represents access to the origin scheme and port.
    CodeConnectAccess a3 = CodeConnectAccess.CreateOriginSchemeAccess(CodeConnectAccess.OriginPort);
    // Add connection access objects to the NetCodeGroup object.
    codeGroup.AddConnectAccess(Uri.UriSchemeHttp, a1);
    codeGroup.AddConnectAccess(Uri.UriSchemeHttp, a2);
    codeGroup.AddConnectAccess(Uri.UriSchemeHttp, a3);
    // Provide name and description information for caspol.exe tool.
    codeGroup.Name = "ContosoHttpCodeGroup";
    codeGroup.Description = "Code originating from contoso.com can connect back using the FTP or HTTPS.";
    // Add the code group to the User policy's root node.
    level.RootCodeGroup.AddChild(codeGroup);
    // Save the changes to the policy level.
    System.Security.SecurityManager.SavePolicy();
}

Remarques

Cette classe est utilisée conjointement avec la classe pour contrôler la façon dont l’exécution NetCodeGroup du code peut se connecter au site à partir duquel il a été téléchargé. Ces classes fournissent un contrôle programmatique de l’accordé à l’exécution WebPermission du code qui contrôle les schémas et les ports que le code peut utiliser pour accéder à son site d’origine. Vous pouvez spécifier des paires de schémas et de ports autorisées en fonction du schéma dans l’URL d’origine du code.

Pour créer un CodeConnectAccess objet basé sur le schéma d’origine du code, utilisez la CreateOriginSchemeAccess méthode .

Pour créer un CodeConnectAccess objet qui peut utiliser n’importe quel schéma, mais qui est limité par le port, utilisez la CreateAnySchemeAccess méthode .

Constructeurs

CodeConnectAccess(String, Int32)

Initialise une nouvelle instance de la classe CodeConnectAccess.

Champs

AnyScheme

Contient la valeur de chaîne qui représente le modèle générique.

DefaultPort

Contient la valeur utilisée pour représenter le port par défaut.

OriginPort

Contient la valeur utilisée pour représenter la valeur de port dans l'URI dont provient le code.

OriginScheme

Contient la valeur utilisée pour représenter le modèle dans l'URL dont provient le code.

Propriétés

Port

Obtient le port représenté par l'instance actuelle.

Scheme

Obtient le modèle URI représenté par l'instance actuelle.

Méthodes

CreateAnySchemeAccess(Int32)

Retourne une instance de CodeConnectAccess qui représente l'accès au port spécifié à l'aide de n'importe quel modèle.

CreateOriginSchemeAccess(Int32)

Retourne une instance de CodeConnectAccess qui représente l'accès au port spécifié à l'aide du modèle de code d'origine.

Equals(Object)

Retourne une valeur qui indique si deux objets CodeConnectAccess représentent le même modèle et le même port.

GetHashCode()

Sert de fonction de hachage pour un type particulier.

GetType()

Obtient le Type de l'instance actuelle.

(Hérité de Object)
MemberwiseClone()

Crée une copie superficielle du Object actuel.

(Hérité de Object)
ToString()

Retourne une chaîne qui représente l'objet actuel.

(Hérité de Object)

S’applique à