从IDE运行应用程序时,IntelliJ不包括对类路径的logback-classic依赖(它是kotlin应用程序,但这无关紧要)。我的gradle构建包含一行:
compile group: 'ch.qos.logback', name: 'logback-classic', version: '1.+'
依赖关系正确列出在IntelliJ中的“外部库”下。
当我尝试手动引用依赖项在源代码中提供的类时,编译器不会抱怨,并且可以成功编译代码。
但是,当我运行应用程序时,我得到ClassNotFoundException。
//This import is provided by logback-classic library
import org.slf4j.impl.StaticLoggerBinder
...
// This compiles successfully, but will trigger ClassNotFoundException when run
val singleton = StaticLoggerBinder.getSingleton()
我包含了列出运行时类路径的代码:
val cl = ClassLoader.getSystemClassLoader()
val urls = (cl as URLClassLoader).urLs
for (url in urls) {
System.out.println(url.file)
}
从IDE运行时,输出不包括经典的logback。样本输出:
...
/Users/knesek/.gradle/caches/modules-2/files-2.1/commons-httpclient/commons-httpclient/3.1/964cd74171f427720480efdec40a7c7f6e58426a/commons-httpclient-3.1.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/com.fasterxml.jackson.core/jackson-databind/2.8.8/bf88c7b27e95cbadce4e7c316a56c3efffda8026/jackson-databind-2.8.8.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/com.fasterxml.jackson.module/jackson-module-jaxb-annotations/2.8.8/e2e95efc46d45be4b429b704efbb1d4b89721d3a/jackson-module-jaxb-annotations-2.8.8.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/com.sun.mail/javax.mail/1.5.6/ab5daef2f881c42c8e280cbe918ec4d7fdfd7efe/javax.mail-1.5.6.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/ch.qos.logback/logback-core/1.1.11/88b8df40340eed549fb07e2613879bf6b006704d/logback-core-1.1.11.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/1.1.1/98e484e67f913e934559f7f55f0c94be5593f03c/kotlin-stdlib-1.1.1.jar
/Users/knesek/.gradle/caches/modules-2/files-2.1/org.springframework/spring-beans/4.3.9.RELEASE/daa5abf3779c8cad1a2910e1ea08e4272489d8ae/spring-beans-4.3.9.RELEASE.jar
...
令人着迷的是,logback-core在其中,而logback-classic不在(并且logback-core是logback-classic的可传递依赖项)。
我尝试使InteliJ cahces无效,重建并重新启动InteliJ。从gradle编译并运行jar可以正常工作。有什么建议么?
最佳答案
看来这是InteliJ中的错误,我将为此提交一个错误报告。针对可能遇到类似问题的任何人,在此处提供此解决方案。
看来,当在类路径上存在某种依赖关系组合时,那么当您使用gradle依赖关系时,就像这样
compile group: 'ch.qos.logback', name: 'logback-classic', version: '1.+'
从IDE中运行时,它不会包含在内。但是,如果您这样包含它:
compile group: 'ch.qos.logback', name: 'logback-classic', version: '1.1.+'
然后就可以了。第一个示例确实工作了一段时间,直到我包含更多的依赖项为止。