创建文件,无法用户删除它C#

时间:2013-06-27 15:44:49

标签: c# file-permissions delete-file

我正在创建一个这样的文件:

System.IO.File.Create("file.dat").Close();

我想设置文件的权限以禁止用户删除它。我尝试了以下方法,但它不起作用:

System.Security.AccessControl.FileSecurity fSecurity = File.GetAccessControl(dirPath + "\\" + fileName);

fSecurity.AddAccessRule(new System.Security.AccessControl.FileSystemAccessRule("Administrators",
    System.Security.AccessControl.FileSystemRights.Delete, System.Security.AccessControl.AccessControlType.Allow));

File.SetAccessControl(dirPath + "\\" + fileName, fSecurity);

1 个答案:

答案 0 :(得分:1)

可以使用System.IO.File.SetAccessControl

设置文件权限

请参阅MSDN上的文档和示例:http://msdn.microsoft.com/en-us/library/system.io.file.setaccesscontrol.aspx

要拒绝向所有用户删除权限,但管理员可以使用此代码

    FileSecurity fSecurity = File.GetAccessControl(fileName);

    AuthorizationRuleCollection rules = fSecurity.GetAccessRules(true, true, typeof(System.Security.Principal.SecurityIdentifier));
    foreach (AuthorizationRule rule in rules)
    {
        System.Security.Principal.NTAccount account = 
            (System.Security.Principal.NTAccount)rule.IdentityReference.Translate(typeof(System.Security.Principal.NTAccount));
        if (account.Value != "BUILTIN\\Administrators")
        {
            fSecurity.AddAccessRule(new FileSystemAccessRule(account.Value, FileSystemRights.Delete, AccessControlType.Deny));
        }
    }

    File.SetAccessControl(fileName, fSecurity);