我在远程服务器上有一个widows文件夹,我希望从该文件夹中删除特定用户的权限。我尝试过很多方法,似乎没什么用。
我没有使用以下代码的错误,但权限保持不变。我没有使用正确的对象或缺少这些对象的一些步骤吗?任何帮助将不胜感激。
dirName作为共享传递,例如\ MYSERVER \ MyFolder文件
private void removePermissions(string dirName, string username)
{
string user = System.Environment.UserDomainName + "\\" + username;
DirectoryInfo dirinfo = new DirectoryInfo(dirName);
DirectorySecurity dsec = dirinfo.GetAccessControl(AccessControlSections.All);
AuthorizationRuleCollection rules = dsec.GetAccessRules(true, true, typeof(System.Security.Principal.NTAccount));
foreach (AccessRule rule in rules)
{
if (rule.IdentityReference.Value == user)
{
bool value;
dsec.PurgeAccessRules(rule.IdentityReference);
dsec.ModifyAccessRule(AccessControlModification.RemoveAll, rule, out value);
MessageBox.Show("Removed permission from " + dirName + " for " + user);
}
}
}
答案 0 :(得分:5)
创建新ACL后,您需要将其应用到文件夹中。
添加
dirinfo.SetAccessControl(dsec);
循环后。