c# watcher怎樣記錄監(jiān)控日志

c#
小樊
81
2024-09-24 17:35:16
欄目: 編程語言

在C#中,你可以使用System.IO.FileSystem.Diagnostics.EventLog類來記錄監(jiān)控日志。以下是一個(gè)簡(jiǎn)單的示例,展示了如何創(chuàng)建一個(gè)文件監(jiān)視器來記錄日志:

using System;
using System.IO;
using System.Text;
using System.Threading.Tasks;
using System.Diagnostics;

namespace Watcher
{
    class Program
    {
        static void Main(string[] args)
        {
            string folderPath = @"C:\path\to\folder";
            string logFileName = "watcher.log";
            string logFilePath = Path.Combine(folderPath, logFileName);

            // 確保日志文件存在
            if (!File.Exists(logFilePath))
            {
                File.Create(logFilePath);
            }

            // 創(chuàng)建一個(gè)監(jiān)視器來監(jiān)視文件夾中的文件更改
            FileSystemWatcher watcher = new FileSystemWatcher(folderPath);

            // 定義要監(jiān)視的事件類型
            watcher.NotifyFilter = NotifyFilters.LastAccess | NotifyFilters.LastWrite
                                  | NotifyFilters.FileName | NotifyFilters.DirectoryName;

            // 注冊(cè)事件處理程序
            watcher.Changed += Watcher_Changed;
            watcher.Created += Watcher_Created;
            watcher.Deleted += Watcher_Deleted;
            watcher.Renamed += Watcher_Renamed;

            // 開始監(jiān)視
            watcher.EnableRaisingEvents = true;

            Console.WriteLine("開始監(jiān)視文件夾: " + folderPath);
            Console.WriteLine("日志文件: " + logFilePath);

            // 等待用戶按下任意鍵退出
            Console.ReadKey();

            // 停止監(jiān)視并注銷事件處理程序
            watcher.EnableRaisingEvents = false;
            watcher.Changed -= Watcher_Changed;
            watcher.Created -= Watcher_Created;
            watcher.Deleted -= Watcher_Deleted;
            watcher.Renamed -= Watcher_Renamed;

            Console.WriteLine("監(jiān)視已停止");
        }

        private static void Watcher_Changed(object source, FileSystemEventArgs e)
        {
            LogEvent("文件已更改: " + e.FullPath);
        }

        private static void Watcher_Created(object source, FileSystemEventArgs e)
        {
            LogEvent("文件已創(chuàng)建: " + e.FullPath);
        }

        private static void Watcher_Deleted(object source, FileSystemEventArgs e)
        {
            LogEvent("文件已刪除: " + e.FullPath);
        }

        private static void Watcher_Renamed(object source, RenamedEventArgs e)
        {
            LogEvent("文件已重命名: " + e.OldFullPath + " -> " + e.FullPath);
        }

        private static void LogEvent(string message)
        {
            // 獲取當(dāng)前時(shí)間
            DateTime now = DateTime.Now;

            // 創(chuàng)建日志條目
            StringBuilder logEntry = new StringBuilder();
            logEntry.AppendLine($"{now}: {message}");

            // 將日志條目追加到日志文件中
            File.AppendAllText(logFilePath, logEntry.ToString());

            // 可選: 將日志條目寫入事件日志
            // EventLog.WriteEntry(logFilePath, message, EventLogEntryType.Information);
        }
    }
}

這個(gè)示例將監(jiān)視指定的文件夾,并在文件更改時(shí)記錄日志。你可以根據(jù)需要修改folderPathlogFileName變量來指定要監(jiān)視的文件夾和日志文件的路徑。

0