Directory.SetAccessControl(String, DirectorySecurity) Methode
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
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 path
angegebene 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:
Verwenden Sie die GetAccessControl-Methode, um das DirectorySecurity Objekt aus der Quelldatei abzurufen.
Erstellen Sie ein neues DirectorySecurity-Objekt für die Zieldatei.
Verwenden Sie die GetSecurityDescriptorBinaryForm- oder GetSecurityDescriptorSddlForm Methode des Quellobjekts DirectorySecurity, um die ACL-Informationen abzurufen.
Verwenden Sie die SetSecurityDescriptorBinaryForm- oder SetSecurityDescriptorSddlForm methode, um die in Schritt 3 abgerufenen Informationen in das Ziel DirectorySecurity Objekts zu kopieren.
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.