Partage via


Sécurité de l'intégration du CLR

S’applique à : SQL Server

Le modèle de sécurité de l’intégration de SQL Server à .NET Framework Common Language Runtime (CLR) gère et sécurise l’accès entre différents types d’objets CLR et non CLR exécutés dans SQL Server. Ces objets peuvent être appelés par une instruction Transact-SQL ou un autre objet CLR en cours d'exécution sur le serveur. Les appels entre objets portent le nom de liens. Les types de vérifications de sécurité effectués sur ces objets dépendent des types de liens impliqués.

Le modèle de sécurité d'intégration du CLR a les objectifs suivants :

  • Par défaut, l’exécution du code utilisateur managé sur SQL Server ne doit pas compromettre l’intégrité et la stabilité de SQL Server. L’exécution d’opérations qui peuvent compromettre la robustesse de SQL Server doit être protégée par des autorisations de haut niveau appropriées.

  • Le code utilisateur managé ne doit pas accéder de façon non autorisée aux données utilisateur ou autre code utilisateur dans la base de données. Le code défini par l'utilisateur doit s'exécuter sous le contexte de sécurité de la session utilisateur qui l'a appelé et avec les privilèges corrects pour ce contexte de sécurité.

  • Il doit y avoir des contrôles pour restreindre le code utilisateur à accéder à toute ressource située à l'extérieur du serveur, de sorte qu'il soit utilisé strictement pour l'accès aux données et le calcul locaux.

  • Le code défini par l’utilisateur ne doit pas être en mesure d’obtenir un accès non autorisé aux ressources système en vertu de l’exécution dans le processus SQL Server.

SQL Server intègre désormais le modèle de sécurité basé sur l’utilisateur de SQL Server avec le modèle de sécurité basé sur l’accès au code du CLR. Quelques-uns des avantages offerts par cette approche combinée de la sécurité sont discutés dans cette section.

Le tableau suivant décrit les rubriques de cette section.

Sécurité d’accès du code d’intégration du CLR
Discute du modèle de sécurité d'accès du code pour le code managé.

Attributs de protection de l’hôte et programmation de l’intégration du CLR
Fournit des informations à propos des valeurs d'attributs de protection de l'hôte (HPA) interdites dans les assemblys SAFE et EXTERNAL_ACCESS.

Liens dans la sécurité d’intégration du CLR
Décrit comment les éléments de code utilisateur peuvent s’appeler les uns les autres dans SQL Server.

Emprunt d’identité et sécurité de l’intégration du CLR
Discute la manière dont le code managé accède aux ressources externes à l'aide de l'emprunt d'identité.

Discute des problèmes qui surviennent lorsqu'une méthode managée appelle une méthode dans une classe contenue dans un autre assembly.

Domaines d’application et sécurité de l’intégration du CLR
Décrit la façon dont les assemblys sont chargés dans les domaines d'application.

Voir aussi

Gestion des assemblys d’intégration du CLR