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 von einem 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 directorySecurity Parameter ist null.
Das Verzeichnis konnte nicht gefunden werden.
Dies path war ungültig.
Der aktuelle Prozess hat keinen Zugriff auf das durch path.
-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 directorySecurity Parameter angegebene ACL ersetzt die vorhandene ACL für das Verzeichnis. Um Berechtigungen für einen neuen Benutzer hinzuzufügen, verwenden Sie 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 Methode oder GetSecurityDescriptorSddlForm die GetSecurityDescriptorBinaryForm Methode des QuellobjektsDirectorySecurity, um die ACL-Informationen abzurufen.
Verwenden Sie die SetSecurityDescriptorBinaryForm oder SetSecurityDescriptorSddlForm die Methode, um die in Schritt 3 abgerufenen Informationen in das Zielobjekt DirectorySecurity zu kopieren.
Legen Sie das Zielobjekt DirectorySecurity mithilfe der SetAccessControl Methode auf die Zieldatei fest.
In NTFS-Umgebungen und ReadExtendedAttributes werden dem Benutzer gewährt, ReadAttributes wenn der Benutzer über Rechte für den übergeordneten Ordner verfügtListDirectory. Um das übergeordnete Verzeichnis zu verweigern ReadAttributes und ReadExtendedAttributeszu verweigern ListDirectory .