https://blog.csdn.net/codepython/article/details/42341243?utm_source=blogxgwz1
使用jnotify
https://blog.csdn.net/stalin_/article/details/80234979
下載資源,添加maven導入
開發時把jnotify_64bit.dll(64位系統用)扔到jdk的jre文件夾下bin目錄比如C:\Program Files\Java\jdk1.8.0_201\jre\bin下
如果是部署,參照rxtx一文https://www.cnblogs.com/jnhs/p/10274667.html
應該把dll放在C:\WINDOWS\system32下才可
新建一個util包
新建一個Jnotify類
/* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates * and open the template in the editor. */ package com.hs.util; import net.contentobjects.jnotify.JNotify; import net.contentobjects.jnotify.JNotifyAdapter; import net.contentobjects.jnotify.JNotifyException; public class Jnotify extends JNotifyAdapter { private static final String REQUEST_BASE_PATH = "D:\\csdnautodl\\tempfile"; /** * 被監視的目錄 */ String path = REQUEST_BASE_PATH; /** * 關注目錄的事件 */ int mask = JNotify.FILE_CREATED | JNotify.FILE_DELETED | JNotify.FILE_MODIFIED | JNotify.FILE_RENAMED; /** * 是否監視子目錄,即級聯監視 */ boolean watchSubtree = true; /** * 監聽程序Id */ public int watchID; /** * 容器啟動時啟動監視程序 * * */ public void beginWatch() { /** * 添加到監視隊列中 */ try { this.watchID = JNotify.addWatch(path, mask, watchSubtree, this); System.err.println("jnotify -----------啟動成功-----------"); } catch (JNotifyException e) { e.printStackTrace(); } /** * 死循環,線程一直執行,休眠一分鍾后繼續執行,主要是為了讓主線程一直執行 休眠時間和監測文件發生的效率無 * (就是說不是監視目錄文件改變一分鍾后才監測到,監測幾乎是實時的,調用本地系統庫) * */ while (true) { try { Thread.sleep(60000); } catch (InterruptedException e) {// ignore it } } } /** * 當監聽目錄下一旦有新的文件被創建,則即觸發該事件 * * @param wd 監聽線程id * @param rootPath 監聽目錄 * @param name 文件名稱 */ @Override public void fileCreated(int wd, String rootPath, String name) { System.err.println("文件被創建, 創建位置為: " + rootPath + "/" + name); } @Override public void fileRenamed(int wd, String rootPath, String oldName, String newName) { System.err.println("文件被重命名, 原文件名為:" + rootPath + "/" + oldName + ", 現文件名為:" + rootPath + "/" + newName); } @Override public void fileModified(int wd, String rootPath, String name) { System.err.println("文件內容被修改, 文件名為:" + rootPath + "/" + name); } @Override public void fileDeleted(int wd, String rootPath, String name) { System.err.println("文件被刪除, 被刪除的文件名為:" + rootPath + name); } }
然后在窗體程序執行的時候開始啟動監視