Compartilhar via


Como fazer para: adicionar ou remover entradas da lista de controle de acesso

Para adicionar ou remover entradas de uma lista de controle de acesso (ACL) de um arquivo ou diretório, obtenha o objeto FileSecurity ou DirectorySecurity no arquivo ou no diretório. Modifique o objeto e, em seguida, aplique-o novamente ao arquivo ou ao diretório.

De um arquivo

  1. Chame o método FileSystemAclExtensions.GetAccessControl(FileInfo) (ou, para aplicativos do .NET Framework, FileInfo.GetAccessControl) para obter um objeto FileSecurity contendo as entradas de ACL atuais de um arquivo.

  2. Adicione ou remova entradas de ACL do objeto FileSecurity obtido na etapa 1.

  3. Para aplicar as alterações, repasse o objeto FileSecurity para o método FileSystemAclExtensions.SetAccessControl(FileInfo, FileSecurity) (ou, para os aplicativos do .NET Framework, FileInfo.SetAccessControl).

A partir de um diretório

  1. Chame o método FileSystemAclExtensions.GetAccessControl(DirectoryInfo) (ou, para aplicativos do .NET Framework, DirectoryInfo.GetAccessControl) para obter um objeto DirectorySecurity contendo as entradas de ACL atuais de um diretório.

  2. Adicione ou remova entradas de ACL do objeto DirectorySecurity obtido na etapa 1.

  3. Para aplicar as alterações, repasse o objeto DirectorySecurity para o método FileSystemAclExtensions.SetAccessControl(DirectoryInfo, DirectorySecurity) (ou, para os aplicativos do .NET Framework, DirectoryInfo.SetAccessControl).

Exemplo

Você precisa especificar uma conta de grupo ou de usuário válida para executar esse exemplo. O exemplo usa um objeto FileInfo. Use o mesmo procedimento para a classe DirectoryInfo.

using System;
using System.IO;
using System.Security.AccessControl;

    class FileExample
    {
        public static void Main()
        {
            try
            {
                string fileName = "test.xml";

                Console.WriteLine($"Adding access control entry for {fileName}");

                // Add the access control entry to the file.
                AddFileSecurity(fileName, @"DomainName\AccountName",
                    FileSystemRights.ReadData, AccessControlType.Allow);

                Console.WriteLine($"Removing access control entry from {fileName}");

                // Remove the access control entry from the file.
                RemoveFileSecurity(fileName, @"DomainName\AccountName",
                    FileSystemRights.ReadData, AccessControlType.Allow);

                Console.WriteLine("Done.");
            }
            catch (Exception e)
            {
                Console.WriteLine(e);
            }
        }

        // Adds an ACL entry on the specified file for the specified account.
        public static void AddFileSecurity(string fileName, string account,
            FileSystemRights rights, AccessControlType controlType)
        {
            FileInfo fileInfo = new(fileName);
            FileSecurity fSecurity = fileInfo.GetAccessControl();

            // Add the FileSystemAccessRule to the security settings.
            fSecurity.AddAccessRule(new FileSystemAccessRule(account,
                rights, controlType));

            // Set the new access settings.
            fileInfo.SetAccessControl(fSecurity);
        }

        // Removes an ACL entry on the specified file for the specified account.
        public static void RemoveFileSecurity(string fileName, string account,
            FileSystemRights rights, AccessControlType controlType)
        {
            FileInfo fileInfo = new(fileName);
            FileSecurity fSecurity = fileInfo.GetAccessControl();

            // Remove the FileSystemAccessRule from the security settings.
            fSecurity.RemoveAccessRule(new FileSystemAccessRule(account,
                rights, controlType));

            // Set the new access settings.
            fileInfo.SetAccessControl(fSecurity);
        }
}
Imports System.IO
Imports System.Security.AccessControl

Module FileExample

    Sub Main()
        Try
            Dim fileName As String = "test.xml"

            Console.WriteLine("Adding access control entry for " & fileName)

            ' Add the access control entry to the file.
            AddFileSecurity(fileName, "DomainName\AccountName",
                FileSystemRights.ReadData, AccessControlType.Allow)

            Console.WriteLine("Removing access control entry from " & fileName)

            ' Remove the access control entry from the file.
            RemoveFileSecurity(fileName, "DomainName\AccountName",
                FileSystemRights.ReadData, AccessControlType.Allow)

            Console.WriteLine("Done.")
        Catch e As Exception
            Console.WriteLine(e)
        End Try

    End Sub

    ' Adds an ACL entry on the specified file for the specified account.
    Sub AddFileSecurity(ByVal fileName As String, ByVal account As String,
        ByVal rights As FileSystemRights, ByVal controlType As AccessControlType)

        Dim fileInfo As New FileInfo(fileName)
        Dim fSecurity As FileSecurity = fileInfo.GetAccessControl()

        ' Add the FileSystemAccessRule to the security settings. 
        Dim accessRule As New FileSystemAccessRule(account, rights, controlType)

        fSecurity.AddAccessRule(accessRule)

        ' Set the new access settings.
        fileInfo.SetAccessControl(fSecurity)

    End Sub

    ' Removes an ACL entry on the specified file for the specified account.
    Sub RemoveFileSecurity(ByVal fileName As String, ByVal account As String,
        ByVal rights As FileSystemRights, ByVal controlType As AccessControlType)

        Dim fileInfo As New FileInfo(fileName)
        Dim fSecurity As FileSecurity = fileInfo.GetAccessControl()

        ' Remove the FileSystemAccessRule from the security settings. 
        fSecurity.RemoveAccessRule(New FileSystemAccessRule(account,
            rights, controlType))

        ' Set the new access settings.
        fileInfo.SetAccessControl(fSecurity)

    End Sub
End Module