C# 文件和目录的监视 – FileSystemWatcher的使用

FileSystemWatcher是C#中用于实时监控文件系统变化的核心类,支持创建、修改、删除、重命名等事件响应,适用于日志监控、配置热加载等场景,需注意缓冲区溢出、事件重复触发及权限等问题。

c# 文件和目录的监视 - filesystemwatcher的使用

在C#中,如果你需要监控文件或目录的变化,比如文件的创建、修改、重命名或删除,FileSystemWatcher 是一个非常实用的类。它位于 System.IO 命名空间下,能够让你实时响应文件系统的变动,适用于日志监控配置文件自动加载、数据同步等场景。

基本用法

使用 FileSystemWatcher 很简单,只需要指定要监视的路径和需要关注的事件类型即可。

示例:监控某个目录下的文本文件修改

支付宝账户登录ecshop插件

支付宝账户登录ecshop插件

支付宝账户登录ecshop插件简介: 先向支付宝申请支付接口,拿到合作身份者ID和安全检验码这两个东西。 把login整个文件夹传到服务器上ecshop安装所在的目录,如果路径不对可以会导致使用失败。 需要修改的文件:alipay_config.php return_url.php可以修改第30行的邮箱域名为你的网站域名。 别的不用改,否则会导致无法使用。

下载

using System;
using System.IO;

class Program
{
    static void Main()
    {
        // 创建监视器实例
        FileSystemWatcher watcher = new FileSystemWatcher();
        
        // 设置监视的目录
        watcher.Path = @"C:/logs";
        
        // 可选:设置过滤条件(只监听 .txt 文件)
        watcher.Filter = "*.txt";
        
        // 指定要监视的更改类型
        watcher.NotifyFilter = NotifyFilters.LastWrite 
                             | NotifyFilters.FileName 
                             | NotifyFilters.DirectoryName;

        // 绑定事件处理程序
        watcher.Changed += OnChanged;
        watcher.Created += OnCreated;
        watcher.Deleted += OnDeleted;
        watcher.Renamed += OnRenamed;

        // 开始监视
        watcher.EnableRaisingEvents = true;

        Console.WriteLine("正在监视目录... 按任意键退出。");
        Console.ReadKey();
    }

    private static void OnChanged(object source, FileSystemEventArgs e)
    {
        Console.WriteLine($"文件 {e.FullPath} 被修改了!");
    }

    private static void OnCreated(object source, FileSystemEventArgs e)
    {
        Console.WriteLine($"文件 {e.FullPath} 被创建了!");
    }

    private static void OnDeleted(object source, FileSystemEventArgs e)
    {
        Console.WriteLine($"文件 {e.FullPath} 被删除了!");
    }

    private static void OnRenamed(object source, RenamedEventArgs e)
    {
        Console.WriteLine($"文件从 {e.OldFullPath} 重命名为 {e.FullPath}");
    }
}

关键属性说明

  • Path:要监视的目录路径。注意只能监视本地目录,不能监视网络路径(除非映射为本地盘符)。
  • Filter:过滤文件名,支持通配符如 “*.txt” 或 “log?.log”。
  • IncludeSubdirectories:是否递归监视子目录,默认 false。
  • NotifyFilter:指定检测哪些类型的更改,例如文件大小、创建时间、文件名等。
  • EnableRaisingEvents:设为 true 才会开始触发事件。

常见问题与注意事项

  • 事件重复触发:在某些操作(如保存文件)中,操作系统可能会引发多个事件。建议在处理逻辑中加入去重或延迟合并机制。
  • 缓冲区溢出:如果事件产生太快,可能造成内部缓冲区溢出,导致丢失事件。可通过设置 InternalBufferSize 属性增大缓冲区(默认 8KB,最大 64KB)。
  • 跨平台兼容性:在 Linux 或 macOS 上使用 .NET Core/.NET 5+ 时,FileSystemWatcher 依赖底层系统 API,行为可能略有差异。
  • 权限要求:运行程序的账户必须对目标目录有读取和监视权限。
  • 资源释放:使用完后应调用 Dispose() 方法释放句柄,避免资源泄漏。

高级技巧

  • 结合 Debounce 机制防抖动:例如用户保存文件时连续触发多次 Changed,可用 Timer 合并处理。
  • 动态调整监视路径或过滤条件:可在运行时修改 Filter 或 Path 并重新启用事件。
  • 配合后台服务使用:将 FileSystemWatcher 集成到 Windows Service 或 ASP.NET Core HostedService 中实现长期监控。

基本上就这些。FileSystemWatcher 功能强大但使用时要注意稳定性和边界情况。合理配置参数并做好异常处理,能让你的文件监控更可靠。

https://www.php.cn/faq/2030828.html

发表回复

Your email address will not be published. Required fields are marked *