设置目录和子项的权限

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

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);