我想将我的可执行文件jar所需的所有.properties文件放在我将运行jar文件的目录之外的子目录中。目前,我的MANIFEST.MF看起来是这样的:如何在jar清单类路径中指定属性文件的目录?
Manifest-Version: 1.0
Build-Jdk: 1.6.0_26
Main-Class: MyMainClass
Class-Path: . conf lib/dependency1.jar
如果我把我的.properties文件在同一目录中的jar文件,一切工作正常。如果我将它们移动到conf
子目录中,则找不到它们。我也试着直接指定.properties文件的路径,例如conf/log4j.properties
。
是我想要做的可能吗?
更新:这里是我的可执行的JAR失败的代码示例:
InputStream stream = getClass().getClassLoader().getResourceAsStream("myproperties.properties");
当myproperties.properties
在conf
子目录,这个语句返回一个空的InputStream。当log4j.properties
在conf
子目录,它输出的警告信息约没有找到它的配置:
log4j:WARN No appenders could be found for logger (MyMainClass).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
谁加载属性文件?执行JAR?或'dependency1.jar'?究竟如何? – BalusC
更新了有关故障的更多详细信息。 –
您是否真的需要将它们放在不同的运行位置,或者更多地将它们组织到开发层次结构中的不同源文件夹中? – Gray