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();
}
}
分享到:
相关推荐
博文链接:https://xzio.iteye.com/blog/159344
这个名为"FileListener.rar"的压缩包提供了一个自定义的文件监听机制,它在Web应用启动时自动开始工作,并且具备定时扫描和文件变更通知功能。以下是对这个机制的详细解释: 首先,`FileMonitor.java`可能是核心的...
FileListener.java文件中给出了文件监听操作的示例代码,可直接在方法中增加代码来完成发现文件或文件夹修改后需要做的事情。另还包括了需要的jar包。
知识点3:使用FileAlterationListenerAdaptor类来处理文件变化事件 FileAlterationListenerAdaptor是Commons-io提供的一个抽象类,用于处理文件变化事件。通过继承这个类,可以实现文件变化事件的处理,例如文件...
3. **RM(Resource Manager)**:资源管理器,与具体的数据库或者其他存储系统交互,实现本地事务的提交和回滚。 Seata支持多种数据库,包括MySQL、Oracle、SQL Server等,以及各种主流的JDBC驱动。此外,它还兼容...
##### 3. DOM4J生成和解析XML文档 **定义**: DOM4J是一个轻量级的Java库,用于处理XML文档,类似于DOM,但更易于使用且性能更高。 **应用场景**: 当需要简单、快速地处理XML文档时,DOM4J是一个很好的选择。 **...
3. 记录日志:使用`TraceSource`的`TraceInformation`、`TraceError`、`TraceWarning`等方法记录不同级别的日志信息。 ```csharp traceSource.TraceInformation("This is an informational message."); traceSource....
3. 在`FileObserverImpl`中启动一个循环,调用`WatchService.take()`方法来获取下一个待处理的事件。这个方法会阻塞直到有事件发生。 4. 处理接收到的事件,调用`FileListener`的相关方法来执行实际的业务逻辑。 ...
`fileListener`是一个用于监听各种文件操作事件的对象,如选择、取消、完成等。 #### 1.3 字节计数 - `totalBytes`: 存储文件的总字节数。 - `uploadedBytes`: 已上传的字节数。 #### 1.4 文件类型过滤 `...
3. **FileListener**: 这是文件监听器的接口,当文件发生变化时,这个接口的实现将被调用。在实际项目中,你可以定义具体的行为,如通知服务、更新数据库等。 4. **FileFilterImpl**: 文件过滤器用于指定只处理特定...