记录文件访问时间

时间:2009-03-05 22:26:18

标签: c# sql ms-access file

因此,我们有一些(或更多,没有人知道)应用程序编写的应用程序已经离开,这些应用程序访问存储在此开发人员旧PC上的Microsoft Access数据库,而后者又从我们的生产SQL数据库中读取。 现在要跟踪所有这些程序,以及它们运行的​​时间,我想保留一个文件访问时间的日志,这可能吗? 显然,如果我读取访问时间,我会修改它。 我们不能依赖修改的时间,因为一些Access数据库只是SQL数据库的链接表。

喜欢在C#中这样做,但没关系。 只需要追踪到哪里运行,一旦我找到它们,就可以修改它们。

感谢。

1 个答案:

答案 0 :(得分:1)

http://msdn.microsoft.com/en-us/library/system.io.filesystemwatcher.aspx

public class Watcher

{

public static void Main()
{
Run();

}

[PermissionSet(SecurityAction.Demand, Name="FullTrust")]
public static void Run()
{
    string[] args = System.Environment.GetCommandLineArgs();

    // If a directory is not specified, exit program.
    if(args.Length != 2)
    {
        // Display the proper way to call the program.
        Console.WriteLine("Usage: Watcher.exe (directory)");
        return;
    }

    // Create a new FileSystemWatcher and set its properties.
    FileSystemWatcher watcher = new FileSystemWatcher();
    watcher.Path = args[1];
    /* Watch for changes in LastAccess and LastWrite times, and
       the renaming of files or directories. */
    watcher.NotifyFilter = NotifyFilters.LastAccess | NotifyFilters.LastWrite
       | NotifyFilters.FileName | NotifyFilters.DirectoryName;
    // Only watch text files.
    watcher.Filter = "*.txt";

    // Add event handlers.
    watcher.Changed += new FileSystemEventHandler(OnChanged);
    watcher.Created += new FileSystemEventHandler(OnChanged);
    watcher.Deleted += new FileSystemEventHandler(OnChanged);
    watcher.Renamed += new RenamedEventHandler(OnRenamed);

    // Begin watching.
    watcher.EnableRaisingEvents = true;

    // Wait for the user to quit the program.
    Console.WriteLine("Press \'q\' to quit the sample.");
    while(Console.Read()!='q');
}

// Define the event handlers.
private static void OnChanged(object source, FileSystemEventArgs e)
{
    // Specify what is done when a file is changed, created, or deleted.
   Console.WriteLine("File: " +  e.FullPath + " " + e.ChangeType);
}

private static void OnRenamed(object source, RenamedEventArgs e)
{
    // Specify what is done when a file is renamed.
    Console.WriteLine("File: {0} renamed to {1}", e.OldFullPath, e.FullPath);
}

}