问题
尝试的方法
问题
示例代码
using System;
using System.IO;
namespace filecheck
{
class Program
{
static void Main(string[] args)
{
int i = 0;
int html = 0;
try
{
string[] filePaths = Directory.GetFiles(@"c:\", "*.html", SearchOption.AllDirectories);
foreach (string files in filePaths)
{
if (Convert.ToBoolean(files.IndexOf("html")))
{
html++;
}
Console.WriteLine(files);
i++;
}
Console.Write("# Files found: {0} Html: {1)", i, html);
}
catch (UnauthorizedAccessException e)
{
Console.WriteLine("The process failed: {0}", e.ToString());
}
catch (Exception e)
{
Console.WriteLine("The process failed: {0}", e.ToString());
}
}
}
}
答案 0 :(得分:2)
不幸的是,处理此问题的唯一方法是手动执行递归。即使在微软自己的sample code中,他们也是这样做的,只是为了避免整个搜索失败,因为无法访问一个或多个目录。
换句话说,只有在您搜索有限的目录子集时才使用SearchOption.AllDirectories
,而您确定这些目录中不包含任何您无法访问的目录。
答案 1 :(得分:0)
要使您的程序与管理员和非管理员用户一起工作,您需要模拟用户或在每次执行或由任何用户使用时将应用程序重新构建为“以管理员身份运行”。要构建此类应用程序,您需要将app.manifest文件添加到项目中,并在app.manifest中取消注释以下设置行
<requestedExecutionLevel level="requireAdministrator" uiAccess="false" />
有关详细信息,请参阅:http://midnightprogrammer.net/post/How-To-Build-UAC-Compatible-Application-In-NET.aspx