【问题标题】:Program not gathering directory information程序不收集目录信息
【发布时间】:2015-05-17 17:48:47
【问题描述】:

我正在开发一个程序,该程序会收集有关机器的信息以进行故障排除。在对以管理员身份运行的程序进行一些工作后,我无法让它正确输出 %windir%\drivers 中的所有文件。我还遇到了当前用户 appdata 引发 UnauthorizedAccessException 并且不输出任何内容的问题。我虽然没问题,我会写一个服务来解决这个问题。在获得基本服务进行测试之后。我仍然没有看到输出。这是服务的代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Globalization;
using System.IO;
using System.Linq;
using System.ServiceProcess;
using System.Text;
using System.Threading.Tasks;

namespace SVCTest
{
    public partial class Service1 : ServiceBase
    {
        public Service1()
        {
            InitializeComponent();
        }

        protected override void OnStart(string[] args)
        {
            while (true)
            {
                OutputDirStructureToFile(
                    Environment.GetEnvironmentVariable("userprofile") + "\\Desktop\\" + Path.GetRandomFileName() + ".txt", 
                    Environment.ExpandEnvironmentVariables("windir") + "\\drivers");
                System.Threading.Thread.Sleep(30000);
            }
        }

        protected override void OnStop()
        {
        }

        /// <summary>
        /// Outputs the structure of a directory to a file.
        /// Uses GetFileStructureRecursive.
        /// </summary>
        /// <param name="outputFileName">The file to be outputed to.</param>
        /// <param name="folder">Directory to get the structure from.</param>
        /// <param name="searchPatern">What to search for. EXAMPLE: *.*</param>
        private void OutputDirStructureToFile(string outputFileName, string folder)
        {
            using (var file = new StreamWriter(outputFileName))
            {
                file.Write(GetFileStrucutre(new DirectoryInfo(folder), "*.*"));
            }
        }
        private string GetFileStrucutre(DirectoryInfo dirInfo, string searchPattern)
        {
            StringBuilder sb = new StringBuilder();

            sb.AppendLine();
            sb.AppendLine("Root " + dirInfo.Root);
            sb.AppendLine();

            sb.Append(GetFileStructureRecursive(dirInfo, searchPattern));

            return sb.ToString();

        }
        private string GetFileStructureRecursive(DirectoryInfo dirInfo, string searchPattern)
        {
            StringBuilder sb = new StringBuilder();

            sb.AppendLine("\r\n Directory of " + dirInfo.FullName + "\r\n");

            foreach (var x in dirInfo.GetFileSystemInfos(searchPattern))
            {
                sb.AppendLine(
                    x.LastWriteTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture).PadRight(25)
                    + x.Name.PadRight(50)
                    );
            }

            foreach (var dir in dirInfo.GetDirectories())
            {
                sb.Append(GetFileStructureRecursive(dir, searchPattern));
            }

            //try
            //{
            //    foreach (var dir in dirInfo.GetDirectories(searchPattern))
            //    {

            //        sb.AppendLine(
            //            dir.LastWriteTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture).PadRight(25)
            //            + String.Empty.PadRight(15)
            //            + dir.Name.PadRight(50)
            //            + dir.Attributes.ToString().PadRight(50)
            //            + dir.LastAccessTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture).PadRight(25)
            //            + dir.CreationTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture)
            //            );
            //    }
            //}
            //catch (UnauthorizedAccessException) { }

            //try
            //{
            //    foreach (var file in dirInfo.GetFiles(searchPattern))
            //    {

            //        sb.AppendLine(
            //            file.LastWriteTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture).PadRight(25)
            //            + file.Length.ToString("N0").PadRight(15)
            //            + file.Name.PadRight(50)
            //            + file.Attributes.ToString().PadRight(50)
            //            + file.LastAccessTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture).PadRight(25)
            //            + file.CreationTime.ToString("yyyy-MM-dd HH:mm:ss", CultureInfo.InvariantCulture)
            //            );
            //    }
            //}
            //catch (UnauthorizedAccessException) { }

            //try
            //{
            //    foreach (var dir in dirInfo.GetDirectories())
            //    {
            //        sb.Append(GetFileStructureRecursive(dir, searchPattern));
            //    }
            //}
            //catch (UnauthorizedAccessException) { }

            return sb.ToString();
        }

    }
}

您会注意到我注释掉了一个块,认为我可能一次访问了太多信息。这是我在安装和启动服务后得到的:

Root C:\

 Directory of C:\Windows\System32\drivers

2011-04-12 01:38:56      en-US                                             
2009-06-10 15:14:29      gm.dls                                            
2009-06-10 15:14:29      gmreadme.txt                                      
2011-04-12 01:38:56      UMDF                                              
2009-07-13 19:19:10      wimmount.sys                                      

 Directory of C:\Windows\System32\drivers\en-US

2011-04-12 01:38:25      bfe.dll.mui                                       
2011-04-12 01:38:22      ndiscap.sys.mui                                   
2011-04-12 01:38:25      pacer.sys.mui                                     
2011-04-12 01:38:27      qwavedrv.sys.mui                                  
2011-04-12 01:38:22      scfilter.sys.mui                                  
2011-04-12 01:38:20      tcpip.sys.mui                                     

 Directory of C:\Windows\System32\drivers\UMDF

2011-04-12 01:38:56      en-US                                             

 Directory of C:\Windows\System32\drivers\UMDF\en-US

那里肯定缺少一些关键驱动程序。对于我的生活,我无法弄清楚为什么它没有收集信息。没有运行 AV,只是更新了 Windows 7 和 VS。我检查了任何奇怪的文件过滤器管理器驱动程序,但我没有看到任何。

【问题讨论】:

  • 这里的小修正,当我移动代码并将OutputDirStructureToFile 调用重写为两行时。我只放了%windir%\drivers。不像输出显示的那样 %windir%\System32\drivers 。另外,当我提到最上面的 %windir%\drivers 时,应该是 %windir%\System32\drivers。对这种混淆感到抱歉。但是您可以看到输出以 %windir%\System32\drivers 开头,这表明我使用正确的输入运行它。
  • 我发现如果我在收集文件信息列表之前获得文件和目录路径,我会得到更多输出。例如:foreach (var x in Directory.GetDirectories(dirInfo.FullName, searchPattern, SearchOption.AllDirectories) { DirectoryInfo d = new DirectoryInfo(x); 和类似地对文件做同样的事情,我得到了更多的输出,但它仍然缺少一些。
  • 好的,让我们简化一下。以下代码不返回完整的目录信息。 IEnumerable&lt;FileSystemInfo&gt; files = new DirectoryInfo("C:\\Windows\\System32\\drivers").EnumerateFileSystemInfos("*", SearchOption.AllDirectories);

标签: c# service system directoryinfo


【解决方案1】:

Missing directory and file info

我简化了我的问题,发现我没有考虑环境中的可视化。

【讨论】:

  • 我还想指出,无论架构如何,C:\Windows\Sysnative 都会返回机器的本机 System32。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2023-03-20
  • 1970-01-01
  • 2016-02-20
  • 1970-01-01
  • 2013-07-09
  • 2015-02-14
  • 1970-01-01
相关资源
最近更新 更多