Freigeben über


Directory.SetAccessControl(String, DirectorySecurity) Methode

Definition

Wendet ACL-Einträge (Access Control List) an, die durch ein DirectorySecurity-Objekt auf das angegebene Verzeichnis beschrieben werden.

public:
 static void SetAccessControl(System::String ^ path, System::Security::AccessControl::DirectorySecurity ^ directorySecurity);
public static void SetAccessControl (string path, System.Security.AccessControl.DirectorySecurity directorySecurity);
static member SetAccessControl : string * System.Security.AccessControl.DirectorySecurity -> unit
Public Shared Sub SetAccessControl (path As String, directorySecurity As DirectorySecurity)

Parameter

path
String

Ein Verzeichnis zum Hinzufügen oder Entfernen von Zugriffssteuerungslisteneinträgen (Access Control List, ACL).

directorySecurity
DirectorySecurity

Ein DirectorySecurity-Objekt, das einen ACL-Eintrag beschreibt, der auf das vom path-Parameter beschriebene Verzeichnis angewendet werden soll.

Ausnahmen

Der parameter directorySecurity ist null.

Das Verzeichnis konnte nicht gefunden werden.

Die path war ungültig.

Der aktuelle Prozess hat keinen Zugriff auf das durch pathangegebene Verzeichnis.

-oder-

Der aktuelle Prozess verfügt nicht über ausreichende Berechtigungen zum Festlegen des ACL-Eintrags.

Hinweise

Die SetAccessControl-Methode wendet ACL-Einträge (Access Control List) auf ein Verzeichnis an, das die nicht inheritierte ACL-Liste darstellt.

Vorsicht

Die für den parameter directorySecurity angegebene ACL ersetzt die vorhandene ACL für das Verzeichnis. Verwenden Sie zum Hinzufügen von Berechtigungen für einen neuen Benutzer die GetAccessControl Methode, um die vorhandene ACL abzurufen und zu ändern.

Eine ACL beschreibt Einzelpersonen und Gruppen, die über bestimmte Aktionen für die angegebene Datei oder das angegebene Verzeichnis verfügen oder nicht über berechtigungen verfügen. Weitere Informationen finden Sie unter How to: Add or Remove Access Control List Entries.

Die SetAccessControl-Methode behält nur DirectorySecurity Objekte bei, die nach der Objekterstellung geändert wurden. Wenn ein DirectorySecurity-Objekt nicht geändert wurde, wird es nicht in einer Datei beibehalten. Daher ist es nicht möglich, ein DirectorySecurity-Objekt aus einer Datei abzurufen und dasselbe Objekt erneut auf eine andere Datei zu anwenden.

So kopieren Sie ACL-Informationen aus einer Datei in eine andere:

  1. Verwenden Sie die GetAccessControl-Methode, um das DirectorySecurity Objekt aus der Quelldatei abzurufen.

  2. Erstellen Sie ein neues DirectorySecurity-Objekt für die Zieldatei.

  3. Verwenden Sie die GetSecurityDescriptorBinaryForm- oder GetSecurityDescriptorSddlForm Methode des Quellobjekts DirectorySecurity, um die ACL-Informationen abzurufen.

  4. Verwenden Sie die SetSecurityDescriptorBinaryForm- oder SetSecurityDescriptorSddlForm methode, um die in Schritt 3 abgerufenen Informationen in das Ziel DirectorySecurity Objekts zu kopieren.

  5. Legen Sie das Zielobjekt DirectorySecurity Objekt mithilfe der SetAccessControl-Methode auf die Zieldatei fest.

In NTFS-Umgebungen werden dem Benutzer ReadAttributes und ReadExtendedAttributes gewährt, wenn der Benutzer über ListDirectory Rechte für den übergeordneten Ordner verfügt. Um ReadAttributes und ReadExtendedAttributeszu verweigern, verweigern Sie ListDirectory im übergeordneten Verzeichnis.

Gilt für:

Weitere Informationen