FileSystemWatcher是監控指定文件或目錄的文件的創建、刪除、改動、重命名等活動;可以動態地定義需要監控的文件類型及文件屬性改動的類型。
1.常用的幾個基本屬性:
(1) Path :設置要監視的目錄的路徑;(2) IncludeSubdirectories :設置是否級聯監視指定路徑中的子目錄(3) Filter :設置篩選字符串,用于確定在目錄中監視哪些類型的文件;(4) NotifyFilter :設置文件的哪些屬性的變動會觸發Changed事件,同時監控多個屬性變動可以按“或”組合;(默認值為 NotifyFilter.LastWrite / NotifyFilter.FileName / NotifyFilter.DirectoryName 組合)
子項: Attributes -- 文件或文件夾的屬性;
CreationTime -- 文件或文件夾的創建時間。
DirectoryName -- 目錄名;
FileName -- 文件名。
LastAccess -- 文件或文件夾上一次打開的日期;
LastWrite -- 上一次向文件或文件夾寫入內容的日期;
Security -- 文件或文件夾的安全設置。
Size 文件或文件夾的大小(常用)
2.常用事件:
(1) Changed :當更改文件和目錄時發生,可以通過NotifyFilter屬性設置觸發該事件的需要文件更改的屬性;(2) Created : 當創建文件和目錄時發生。
(3) Deleted : 刪除文件或目錄時發生;(4) Renamed :重命名文件或目錄時發生。
(5) FileSystemEventArgs 對象:
成員:Name:獲取受影響的文件或目錄的名稱;注意:如果是級聯監控子目錄的話,該值為從監控目錄的下個目錄到受影響的文件的路徑,而不只是受影響的文件名。
FullPath : 獲取受影響的文件或目錄的完全限定的路徑; ChangeType :獲取受影響的文件或目錄的發生的事件類型。
子項:All -- 文件或文件夾的創建、刪除、更改或重命名;Changed -- 文件或文件夾的更改。更改的類型包括大小、屬性、安全設置、近期寫入時間和近期訪問時間方面的更改。
Created -- 文件或文件夾的創建;Deleted -- 文件或文件夾的刪除。
Renamed -- 文件或文件夾的重命名。
(6) RenamedEventArgs 對象:
成員:Name:獲取受影響的文件或目錄的新名稱; OldName : 獲取受影響的文件或目錄的舊名稱。
FullPath :獲取受影響的文件或目錄的完全限定的路徑;OldFullPath : 獲取受影響的文件或目錄的前一個完全限定的路徑。
ChangeType :獲取受影響的文件或目錄的發生的事件類型;子項:All -- 文件或文件夾的創建、刪除、更改或重命名。
Changed -- 文件或文件夾的更改,更改的類型包括大小、屬性、安全設置、近期寫入時間和近期訪問時間方面的更改;Created -- 文件或文件夾的創建。
Deleted -- 文件或文件夾的刪除;Renamed -- 文件或文件夾的重命名。
重點:
1、因為FileSystemWatcher類本身就是多線程的控件。也就是每實例化一個FileSystemWatcher自動就會創建一條線程。
2、我們需要利用委托進行跨線程更新UI界面,因為重命名事件傳遞的是RenameEventArgs對象。而創建、修改、刪除事件傳遞的是FileEventArgs對象,所以需要聲明兩個委托。
3、如果需要同時監控多個文件(如監控系統全盤)。只需要創建FileSystemWatcher數組,每個文件用一個FileSystemWatcher進行監控。
創建一個簡單的 file 監視:
接下來我們在 Visual Studio 中創建一個 Console 程序,用來了解如何進行文件監視。不過建議把 Console 部署成 Windows Service,這樣方便在系統中常駐監控,一旦被監視的路徑發生變更就會自動發出通知事件。
該說的都說了,接下來一起研究代碼吧。
下面的代碼片段展示了 MonitorDirectory 方法的內部邏輯。這個方法可用于監視指定的文件夾并且當文件夾變更時觸發事件。可以看到文件夾路徑是通過參數傳進去的。
12下一頁>
- 軟件性質:國產軟件
- 授權方式:免費版
- 軟件語言:簡體中文
- 軟件大小:2165 KB
- 下載次數:889 次
- 更新時間:2021/4/12 12:24:43
- 運行平臺:WinXP,Win7...
- 軟件描述:C#文件監控 服務器監控 防止黑客入侵文件篡改、用fileSystemWatch... [立即下載]