Jar文件配置文件路径问题
来源:互联网 发布:php博客聊天源码 编辑:程序博客网 时间:2024/06/06 04:55
背景:在Eclipse中运行的时候,一切正常。把Java工程导成了可运行Java文件,通过java -jar XX.jar命令运行的时候,会报异常说配置文件路径找不到。
解决:
虽然不太确定,但是web工程的配置文件的路径查找和可运行Jar文件的路径查找方式不同。下面描述的是在可运行Jar文件中的配置文件的查找方法。
1. 我的工程结构如下:
注:
a. EnnDataDownloader.ini是工程的一下配置信息。log4j.properties是log4j的配置文件。
b. 请注意这两个文件在工程的根目录,不是在src下。
2. 读取EnnDataDownloader.ini,如下:
package com.ecity.enn.sap.download.util;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.util.Enumeration;import java.util.HashMap;import java.util.Properties;public class ConfigUtil { private static final String INI_FILE_NAME = "/EnnDataDownloader.ini"; private static HashMap<String, String> propertyMap = null; static { propertyMap = new HashMap<String, String>(); FileInputStream inStream = null; try { String path = URLUtil.getProjectHomePath() + INI_FILE_NAME; inStream = new FileInputStream(path); LogUtil.info("Loaded init file."); } catch (FileNotFoundException e) { LogUtil.error(e); } Properties properties = new Properties(); try { properties.load(inStream); } catch (IOException e) { LogUtil.error(e); } @SuppressWarnings("unchecked") Enumeration<String> keys = (Enumeration<String>) properties.propertyNames(); while (keys.hasMoreElements()) { String key = keys.nextElement(); propertyMap.put(key.toLowerCase(), properties.getProperty(key)); } } public static String get(String key) { return propertyMap.get(key.toLowerCase()); } public static int getInt(String key) { String valueStr = propertyMap.get(key.toLowerCase()); int value = 0; try { value = Integer.valueOf(valueStr); } catch (Exception e) { LogUtil.error(e); value = 0; } return value; } public static void set(String key, String value) { if (get(key) == null) { propertyMap.put(key, value); } }}
3. 读取log4j.properties。参考LogUtil.java和log4j.properties。如下:
package com.ecity.enn.sap.download.util;import org.apache.log4j.Logger;import org.apache.log4j.PropertyConfigurator;public class LogUtil { private static final Logger logger; private static final String TAG = "EnnDataDownloader"; private static final String INI_FILE_NAME = "/log4j.properties"; static { String path = URLUtil.getProjectHomePath() + INI_FILE_NAME; PropertyConfigurator.configure(path); logger = Logger.getLogger(TAG); } public static void debug(Object message) { logger.info(message); } public static void debug(String message, Throwable e) { logger.info(message, e); } public static void info(String message) { logger.info(message); } public static void info(String message, Throwable e) { logger.info(message, e); } public static void error(String message) { logger.error(message); } public static void warn(Object message, Throwable e) { logger.warn(message, e); } public static void warn(Throwable e) { logger.warn("", e); } public static void error(Object message, Throwable e) { logger.error(message, e); } public static void error(Throwable e) { logger.error("", e); }}
log4j.rootLogger=INFO, ServerDailyRollingFile, stdoutlog4j.appender.ServerDailyRollingFile=org.apache.log4j.DailyRollingFileAppenderlog4j.appender.ServerDailyRollingFile.DatePattern='.'yyyy-MM-ddlog4j.appender.ServerDailyRollingFile.File=EnnDataDownloader.loglog4j.appender.ServerDailyRollingFile.layout=org.apache.log4j.PatternLayoutlog4j.appender.ServerDailyRollingFile.layout.ConversionPattern=%d - %m%nlog4j.appender.ServerDailyRollingFile.Append=truelog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n
注:两个java文件中,都用到了URLUtil.getProjectHomePath()。实现如下:
/** * Used to get locating directory of a runnable jar file. Not for web project. * @return Directory of the running file. */ public static String getProjectHomePath() { return System.getProperty("user.dir"); }
4. 运行时的文件结构如下:
注:
a. start.bat内容是一个cmd命令,来启动控制台。方便直接运行run_jar.bat。
b. run_jar.bat内容是一个java -jar EnnDataDownloader.jar命令,来运行导出的可运行jar包。
c. 请注意ConfigUtil和LogUtil是如何获取文件路径的。getProjectHomePath方法是关键。
d. 用上面log4j.properties的配置,log文件也生成在同一个目录。
0 0
- Jar文件配置文件路径问题
- jar包 配置文件路径问题
- java jar 配置文件的相对路径问题
- JAR包文件路径问题
- 关于系统读取properties配置文件的路径问题,包括打成jar包的运行文件
- Myeclipse导出jar文件图片路径问题
- 打包jar文件的资源路径问题
- Log4J配置文件日志文件路径问题
- properties文件jar 路径
- JAVA Jar 路径问题
- jar包路径问题
- hadoop中javac编译添加jar库文件路径问题
- java读取jar包中的资源文件或properties配置文件路径的方法
- java读取jar包中的资源文件或properties配置文件路径的方法
- 打成jar包的xml配置文件无法找到路径,System.getProperty("user.dir")解决该问题
- 解决项目打jar包后无法获取配置文件的路径问题
- jar包中配置文件路径的读取
- 关于java配置文件路径问题
- 函数readv 和函数writev
- 等差数列
- HDU 5304 Eastest Magical Day Seep Group's Summer(状压DP+环缩点+生成树计数)
- Spring 4.x框架中的新特性---Spring4.0框架的新功能和改善
- 最长公共子串
- Jar文件配置文件路径问题
- C++函数模板与类模板实例解析
- 基于opencv的相机之增加图库功能(五)
- mysql在表中添加多个外键/增加外键/级联约束
- 关于C++中模板中的typename和class的区别比较
- 集合视图
- 中文知识图谱研讨会的学习总结 (上) 图谱引入、百度知心、搜狗知立方
- 并查集杭电1272小希的迷宫
- 在Visual Studio 2013 中编写C语言、C++程序