我想將我的可執行文件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