Freigeben über


File.SetAccessControl(String, FileSecurity) Methode

Definition

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:

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

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

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

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

  5. 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.

Gilt für:

Weitere Informationen