Directoy.Delete(path, true) ->IOException:目录不为空->Win7上不同的用户
本文关键字:Win7 用户 path Delete true Directoy IOException | 更新日期: 2023-09-27 18:14:46
在卸载时,我在试图删除目录时得到IOException。'目录不是空的'。我尝试了下面列出的不同方法,但都不起作用。留下的(不能删除的)文件有不同的所有者。可以删除的文件的所有者为'SYSTEM'。抛出异常的文件的所有者为"Administrators(PC_Name'Administrators)"系统"文件是由installshield安装程序(MSI)编写的,而其他文件是由我的应用程序编写的,由installshield启动并提升为管理员…
如何强制删除这个文件夹/文件?
//http://stackoverflow.com/questions/329355/cannot-delete-directory-with-directory-deletepath-true
public static bool DeleteDirectory(string target_dir)
{
bool result = false;
string[] files = Directory.GetFiles(target_dir);
string[] dirs = Directory.GetDirectories(target_dir);
foreach (string file in files)
{
File.SetAttributes(file, FileAttributes.Normal);
File.Delete(file);
}
foreach (string dir in dirs)
{
DeleteDirectory(dir);
}
Directory.Delete(target_dir, false);
return result;
}
//http://stackoverflow.com/questions/611921/how-do-i-delete-a-directory-with-read-only-files-in-c
private static void DeleteFileSystemInfo(FileSystemInfo fsi)
{
fsi.Attributes = FileAttributes.Normal;
var di = fsi as DirectoryInfo;
if (di != null)
{
foreach (var dirInfo in di.GetFileSystemInfos())
DeleteFileSystemInfo(dirInfo); }
fsi.Delete();
}
//http://stackoverflow.com/questions/611921/how-do-i-delete-a-directory-with-read-only-files-in-c
public static void ForceDeleteDirectory(string path)
{
DirectoryInfo root;
Stack<DirectoryInfo> fols;
DirectoryInfo fol;
fols = new Stack<DirectoryInfo>();
root = new DirectoryInfo(path);
fols.Push(root);
while (fols.Count > 0)
{
fol = fols.Pop();
fol.Attributes = fol.Attributes & ~(FileAttributes.Archive | FileAttributes.ReadOnly | FileAttributes.Hidden);
foreach (DirectoryInfo d in fol.GetDirectories())
{
fols.Push(d);
}
foreach (FileInfo f in fol.GetFiles())
{
f.Attributes = f.Attributes & ~(FileAttributes.Archive | FileAttributes.ReadOnly | FileAttributes.Hidden);
f.Delete();
}
}
root.Delete(true);
}
编辑:对不起,忘记了:
在给出问题的文件夹上,在安装时,我给'Users'帐户完全控制:
System.Security.Principal.SecurityIdentifier sid = new System.Security.Principal.SecurityIdentifier(
System.Security.Principal.WellKnownSidType.BuiltinUsersSid, null);
System.Security.Principal.NTAccount acct = sid.Translate(typeof(System.Security.Principal.NTAccount))
as System.Security.Principal.NTAccount;
string usr = acct.ToString();
DirectoryInfo info = new DirectoryInfo(dir);
DirectorySecurity ds = info.GetAccessControl();
ds.AddAccessRule(new FileSystemAccessRule(usr, FileSystemRights.FullControl, AccessControlType.Allow));
ds.AddAccessRule(new FileSystemAccessRule(usr, FileSystemRights.FullControl,
InheritanceFlags.ObjectInherit | InheritanceFlags.ContainerInherit, PropagationFlags.InheritOnly,
AccessControlType.Allow));
info.SetAccessControl(ds);
有两个常见的选项会导致这个问题:
1)您的应用程序以非administrator用户运行。
2)您的应用程序仍然以某种方式持有由它创建的文件的锁。
第一个选项不太可能,因为文件是由它创建的,所以让我们以第二个选项为中心。为了方便地识别这个问题,在应用程序运行时(如果进程很快,您可以使用调试器暂停它),尝试手动删除这些文件。如果失败,则表示应用程序仍然有锁。
如果是这种情况,请确保关闭所有文件流并正确处理它们。