File.SetAccessControl(String, FileSecurity) Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Applique les entrées de liste de contrôle d’accès (ACL) décrites par un FileSecurity objet au fichier spécifié.
public:
static void SetAccessControl(System::String ^ path, System::Security::AccessControl::FileSecurity ^ fileSecurity);
public static void SetAccessControl(string path, System.Security.AccessControl.FileSecurity fileSecurity);
static member SetAccessControl : string * System.Security.AccessControl.FileSecurity -> unit
Public Shared Sub SetAccessControl (path As String, fileSecurity As FileSecurity)
Paramètres
- path
- String
Fichier à partir duquel ajouter ou supprimer des entrées de liste de contrôle d’accès (ACL).
- fileSecurity
- FileSecurity
Objet FileSecurity qui décrit une entrée de liste de contrôle d’accès à appliquer au fichier décrit par le path paramètre.
Exceptions
Une erreur d’E/S s’est produite lors de l’ouverture du fichier.
Le path paramètre est null.
Impossible de trouver le fichier.
Le path paramètre a spécifié un fichier en lecture seule.
-ou-
Cette opération n’est pas prise en charge sur la plateforme actuelle.
-ou-
Le path paramètre a spécifié un répertoire.
-ou-
L’appelant n’a pas l’autorisation requise.
Le fileSecurity paramètre est null.
Remarques
La SetAccessControl méthode applique des entrées de liste de contrôle d’accès (ACL) à un fichier qui représente la liste ACL non utilisée.
Avertissement
La liste de contrôle d’accès spécifiée pour le fileSecurity paramètre remplace la liste de contrôle d’accès existante pour le fichier. Pour ajouter des autorisations pour un nouvel utilisateur, utilisez la GetAccessControl méthode pour obtenir la liste de contrôle d’accès existante, la modifier, puis pour SetAccessControl l’appliquer au fichier.
Une liste de contrôle d’accès décrit les personnes et les groupes qui ont, ou n’ont pas, des droits pour des actions spécifiques sur le fichier donné. Pour plus d’informations, consultez Comment : ajouter ou supprimer des entrées de liste de contrôle d’accès.
La SetAccessControl méthode conserve uniquement FileSecurity les objets qui ont été modifiés après la création de l’objet. Si un FileSecurity objet n’a pas été modifié, il ne sera pas conservé dans un fichier. Par conséquent, il n’est pas possible de récupérer un FileSecurity objet à partir d’un fichier et de réappliquer le même objet à un autre fichier.
Pour copier des informations de liste de contrôle d’accès d’un fichier vers un autre :
Utilisez la GetAccessControl méthode pour récupérer l’objet FileSecurity à partir du fichier source.
Créez un FileSecurity objet pour le fichier de destination.
Utilisez la ou GetSecurityDescriptorSddlForm la GetSecurityDescriptorBinaryForm méthode de l’objet source FileSecurity pour récupérer les informations de liste de contrôle d’accès.
Utilisez la ou SetSecurityDescriptorSddlForm la SetSecurityDescriptorBinaryForm méthode pour copier les informations récupérées à l’étape 3 vers l’objet de destinationFileSecurity.
Définissez l’objet de destination FileSecurity sur le fichier de destination à l’aide de la SetAccessControl méthode.
Dans les environnements NTFS, ReadAttributes et ReadExtendedAttributes sont accordés à l’utilisateur si l’utilisateur dispose ListDirectory de droits sur le dossier parent. Pour refuser et ReadExtendedAttributesrefuser ReadAttributesListDirectory sur le répertoire parent.