Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/280.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 设置目录和子项的权限_C#_.net_Permissions_File Permissions_User Permissions - Fatal编程技术网

C# 设置目录和子项的权限

C# 设置目录和子项的权限,c#,.net,permissions,file-permissions,user-permissions,C#,.net,Permissions,File Permissions,User Permissions,我的程序将一些目录、子目录和文件从服务器复制到本地计算机。我需要,每个本地用户都可以修改它(编辑/删除/删除/重命名)。但现在它只能做所有者。如何为复制的目录及其子项设置必要的权限? 我尝试这样的代码: String account = Path.Combine(Environment.MachineName, "Users"); FileSystemRights rights = FileSystemRights.FullControl; AccessControlType controlTy

我的程序将一些目录、子目录和文件从服务器复制到本地计算机。我需要,每个本地用户都可以修改它(编辑/删除/删除/重命名)。但现在它只能做所有者。如何为复制的目录及其子项设置必要的权限? 我尝试这样的代码:

String account = Path.Combine(Environment.MachineName, "Users");
FileSystemRights rights = FileSystemRights.FullControl;
AccessControlType controlType = AccessControlType.Allow;
DirectorySecurity security = local_commonDir.GetAccessControl(AccessControlSections.Access);
FileSystemAccessRule rule = new FileSystemAccessRule(account, rights, controlType);
security.AddAccessRule(rule);
local_commonDir.SetAccessControl(security);
但我有个例外:

无法转换某些属性或属性链接

如果添加缺少的访问控制,则不会出现错误。我认为接收错误是因为“用户”已经存在。如何更改现有权限?

我找到了解决方案:

WindowsIdentity id = WindowsIdentity.GetCurrent();
var sid = new SecurityIdentifier(WellKnownSidType.AccountDomainUsersSid, id.User.AccountDomainSid);
var security = dir.GetAccessControl();
var rule = new FileSystemAccessRule(sid,
    FileSystemRights.FullControl,
    InheritanceFlags.ContainerInherit | InheritanceFlags.ObjectInherit,
    PropagationFlags.None,
    AccessControlType.Allow);
security.AddAccessRule(rule);
dir.SetAccessControl(security);

使用帐户名(用户名、组名)和
非SID
?@Kiquenet,还可以通过用户名()调用FileSystemAccessRule构造函数