Разрешения на чтение для каталога в C # - PullRequest
7 голосов
/ 16 февраля 2010

Я заметил, что если вы измените настройки безопасности для определенного каталога, вы можете сделать эту папку больше не доступной для просмотра в Windows. В частности, изменение разрешения «Чтение» для администраторов на «Запретить» сделает эту папку недоступной.

Вопрос, который у меня сейчас есть, как мне понять это в коде? Я слежу за мной, но это все равно не так:

/// <summary>
/// Takes in a directory and determines if the current user has read access to it (doesn't work for network drives)
/// THIS IS VERY HACKY
/// </summary>
/// <param name="dInfo">directoryInfo object to the directory to examine</param>
/// <returns>true if read access is available, false otherwise</returns>
public static bool IsDirectoryReadable(DirectoryInfo dInfo)
{
    try
    {
        System.Security.AccessControl.DirectorySecurity dirSec = dInfo.GetAccessControl();
        System.Security.Principal.WindowsIdentity self = System.Security.Principal.WindowsIdentity.GetCurrent();
        System.Security.Principal.WindowsPrincipal selfGroup = new System.Security.Principal.WindowsPrincipal(self);
        // Go through each access rule found for the directory
        foreach (System.Security.AccessControl.FileSystemAccessRule ar in dirSec.GetAccessRules(true, true, typeof(System.Security.Principal.SecurityIdentifier)))
        {
            if (selfGroup.IsInRole((System.Security.Principal.SecurityIdentifier)ar.IdentityReference))
            {
                // See if the Read right is included
                if ((ar.FileSystemRights & System.Security.AccessControl.FileSystemRights.Read) == System.Security.AccessControl.FileSystemRights.Read)
                {
                    if (ar.AccessControlType == System.Security.AccessControl.AccessControlType.Allow)
                    {
                        // If all of the above are true, we do have read access to this directory
                        return true;
                    }
                    else
                    {
                        return false;
                    }
                }
            }
        }
        // If we didn't find anything
        return false;
    }
    catch
    {
        // If anything goes wrong, assume false
        return false;
    }
}

Я близок к вышесказанному, но мне все еще не хватает чего-то огромного. Если щелкнуть правой кнопкой мыши папку, чтобы установить разрешения, я вижу (в моем примере) 3 группы или имена пользователей: «Администраторы, myUserName и SYSTEM». Если я установлю для параметра «Чтение» значение «Запретить» для «Администраторы» или «myUserName», я больше не смогу просматривать каталог. Если я только установлю «Система» на «Запретить», я все равно смогу просмотреть его.

Кажется, что подразумевается какая-то иерархия разрешений, в которой myUserName или Administrator заменяют группу / пользователя SYSTEM.

Приведенный выше код ищет первое «Разрешить» для «Чтение», которое он находит для моей идентификации пользователя и возвращает true. Я также мог бы написать код, который ищет первое «Deny» для Read и возвращает false.

Я могу установить папку «Чтение» - «Запретить» для SYSTEM и «Чтение» - «Разрешить» для двух других учетных записей и при этом читать папку. Если я изменю код для поиска Deny's, и он сначала встретится с идентификатором пользователя SYSTEM, моя функция вернет «false», что ... false. Это вполне может быть прочитано - «Разрешить» для двух других учетных записей.

Проблема, которую я до сих пор не могу понять, заключается в том, как определить, какое разрешение на идентификацию пользователя имеет приоритет над всеми остальными?

Ответы [ 3 ]

3 голосов
/ 16 февраля 2010

Это очень сложно, потому что ACL допускают наследование, но у них также есть модель наиболее ограниченного доступа. Другими словами, если у вас есть DENY где-нибудь в вашей цепочке пользователей к ресурсу, независимо от того, сколько других групп может дать вам разрешение, вам будет отказано. Есть хорошая статья на тему MSDN .

2 голосов
/ 16 февраля 2010

Системная группа относится к процессу O / S и не имеет прямого отношения к вашей учетной записи пользователя. Это то, что O / S использовал бы для доступа к файловой системе, если бы не было пользовательского контекста. Поскольку ваше приложение работает под вашим «именем пользователя», от него поступают разрешения и группы, в которые он входит. Не думайте, что вам нужно проверять систему в этом случае, если я что-то не упустил.

Обновление: Имейте в виду, что Directory.Exists () также проверит, есть ли у вас разрешения на чтение каталога.

0 голосов
/ 30 марта 2010

Проблема не в иерархии разрешений. Проблема в том, что ваш код возвращает true или false в зависимости от первой подходящей роли. Вам действительно нужно оценить все разрешения.

Мне недавно пришлось столкнуться с этой проблемой ... Я разместил свой код здесь .

...