File.SetAccessControl(String, FileSecurity) 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 FileSecurity-Objekt auf die angegebene Datei beschrieben werden.
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)
Parameter
- path
- String
Eine Datei zum Hinzufügen oder Entfernen von Zugriffssteuerungslisteneinträgen (Access Control List, ACL).
- fileSecurity
- FileSecurity
Ein FileSecurity-Objekt, das einen ACL-Eintrag beschreibt, der auf die vom path
-Parameter beschriebene Datei angewendet werden soll.
Ausnahmen
Beim Öffnen der Datei ist ein E/A-Fehler aufgetreten.
Der parameter path
ist null
.
Die Datei konnte nicht gefunden werden.
Der path
Parameter hat eine Datei angegeben, die schreibgeschützt ist.
-oder-
Dieser Vorgang wird auf der aktuellen Plattform nicht unterstützt.
-oder-
Der path
Parameter hat ein Verzeichnis angegeben.
-oder-
Der Aufrufer verfügt nicht über die erforderliche Berechtigung.
Der parameter fileSecurity
ist null
.
Hinweise
Die SetAccessControl Methode wendet ACL-Einträge (Access Control List) auf eine Datei an, die die nicht inheritierte ACL-Liste darstellt.
Vorsicht
Die für den parameter fileSecurity
angegebene ACL ersetzt die vorhandene ACL für die Datei. Verwenden Sie zum Hinzufügen von Berechtigungen für einen neuen Benutzer die GetAccessControl Methode, um die vorhandene ACL abzurufen, sie zu ändern, und verwenden Sie dann SetAccessControl, um sie wieder auf die Datei anzuwenden.
Eine ACL beschreibt Einzelpersonen und Gruppen, die über bestimmte Aktionen für die angegebene Datei verfügen oder keine Rechte haben. Weitere Informationen finden Sie unter How to: Add or Remove Access Control List Entries.
Die SetAccessControl-Methode behält nur FileSecurity Objekte bei, die nach der Objekterstellung geändert wurden. Wenn ein FileSecurity-Objekt nicht geändert wurde, wird es nicht in einer Datei beibehalten. Daher ist es nicht möglich, ein FileSecurity-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 FileSecurity Objekt aus der Quelldatei abzurufen.
Erstellen Sie ein neues FileSecurity-Objekt für die Zieldatei.
Verwenden Sie die GetSecurityDescriptorBinaryForm- oder GetSecurityDescriptorSddlForm Methode des Quellobjekts FileSecurity, um die ACL-Informationen abzurufen.
Verwenden Sie die SetSecurityDescriptorBinaryForm- oder SetSecurityDescriptorSddlForm methode, um die in Schritt 3 abgerufenen Informationen in das Ziel FileSecurity Objekts zu kopieren.
Legen Sie das Zielobjekt FileSecurity 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.