`
Xgw123485
  • 浏览: 87489 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

FileListener -3

阅读更多
private void loadProperties()
{
//更新时间
this.lastModified = file.lastModified();

try
{
logger.info("The properties file[" + getPath() + "] loading ...");

FileInputStream in = new FileInputStream(file);
prop.load(in);

//print all properties
Enumeration<?> enu = prop.propertyNames();
StringBuffer buf = new StringBuffer();
while (enu.hasMoreElements())
{
String key = (String)enu.nextElement();
buf.append("     key: ").append(key).append(",     value: ").append(prop.getProperty(key)).append("\n");
}
logger.info(buf.toString());
logger.info("The properties file[" + getPath() + "] load complete.");

//如果是log4J.properties文件更新,需要加载配置以便立即生效
if ("log4j.properties".equalsIgnoreCase(getFileName()))
            {
                PropertyConfigurator.configure(getProperties());
            }
in.close();
}
catch (FileNotFoundException e)
{
logger.error("The file[" + getPath() + "] doesn't exist, reload file unsuccess.");
e.printStackTrace();
}
catch (IOException e)
{
logger.error("System IO Error, reload file[" + getPath() + "] unsuccess.");
e.printStackTrace();
}
}
//加载枚举文件
private void loadXml()
{
//更新时间
enumerateFiles.get(currentEnumFilePath).setEnumLastModifieds(enumerateFiles.get(currentEnumFilePath).getEnumFile().lastModified());
//KXml解析器
KXmlParser parser = new KXmlParser ();

//转换为Element
Document doc = new Document();

try
{
logger.info("The properties file[" + currentEnumFilePath + "] loading ...");
//打印原文件
println();

//解析文件
FileInputStream in = new FileInputStream(enumerateFiles.get(currentEnumFilePath).getEnumFile());

InputStreamReader reader =  new InputStreamReader(in);

parser.setInput(reader);

parser.setFeature(XmlPullParser.FEATURE_PROCESS_NAMESPACES, true);

doc.parse(parser);

enumerateFiles.get(currentEnumFilePath).setEnumElement(doc.getRootElement());

//logger.info("The file load:" + xmlBuf.toString());
logger.info("The properties file[" + currentEnumFilePath + "] load complete.");
}
catch (XmlPullParserException e)
{
logger.error("The file[" + currentEnumFilePath + "] parser error,please check again.");
e.printStackTrace();
}
catch (FileNotFoundException e)
{
logger.error("The file[" + currentEnumFilePath + "] doesn't exist, reload file unsuccess.");
e.printStackTrace();
}
catch (IOException e)
{
logger.error("System IO Error, reload file[" + currentEnumFilePath + "] unsuccess.");
e.printStackTrace();
}
catch (Exception e)
{
logger.error("loadXml file[" + currentEnumFilePath + "] unsuccess.");
e.printStackTrace();
}
}
分享到:
评论

相关推荐

    请教import org.apache.commons.vfs.FileListener接口监听

    博文链接:https://xzio.iteye.com/blog/159344

    FileListener.rar

    这个名为"FileListener.rar"的压缩包提供了一个自定义的文件监听机制,它在Web应用启动时自动开始工作,并且具备定时扫描和文件变更通知功能。以下是对这个机制的详细解释: 首先,`FileMonitor.java`可能是核心的...

    文件监听工具使用示例和需要的jar包.rar

    FileListener.java文件中给出了文件监听操作的示例代码,可直接在方法中增加代码来完成发现文件或文件夹修改后需要做的事情。另还包括了需要的jar包。

    Java实现实时监控目录下文件变化的方法

    知识点3:使用FileAlterationListenerAdaptor类来处理文件变化事件 FileAlterationListenerAdaptor是Commons-io提供的一个抽象类,用于处理文件变化事件。通过继承这个类,可以实现文件变化事件的处理,例如文件...

    分布式中间件Seata

    3. **RM(Resource Manager)**:资源管理器,与具体的数据库或者其他存储系统交互,实现本地事务的提交和回滚。 Seata支持多种数据库,包括MySQL、Oracle、SQL Server等,以及各种主流的JDBC驱动。此外,它还兼容...

    C# 使用TraceSource记录程序日志【免费分享】

    3. 记录日志:使用`TraceSource`的`TraceInformation`、`TraceError`、`TraceWarning`等方法记录不同级别的日志信息。 ```csharp traceSource.TraceInformation("This is an informational message."); traceSource....

    java实现文件变化监控的方法(推荐)

    3. 在`FileObserverImpl`中启动一个循环,调用`WatchService.take()`方法来获取下一个待处理的事件。这个方法会阻塞直到有事件发生。 4. 处理接收到的事件,调用`FileListener`的相关方法来执行实际的业务逻辑。 ...

    FLASH 上传大文件带进度条

    `fileListener`是一个用于监听各种文件操作事件的对象,如选择、取消、完成等。 #### 1.3 字节计数 - `totalBytes`: 存储文件的总字节数。 - `uploadedBytes`: 已上传的字节数。 #### 1.4 文件类型过滤 `...

    Java实现文件变化监控

    3. **FileListener**: 这是文件监听器的接口,当文件发生变化时,这个接口的实现将被调用。在实际项目中,你可以定义具体的行为,如通知服务、更新数据库等。 4. **FileFilterImpl**: 文件过滤器用于指定只处理特定...

Global site tag (gtag.js) - Google Analytics