Java SLF4J:类路径包含多个SLF4J绑定。多个logback经典jar
我正在使用gradle构建并运行SpringWeb应用程序。有多个绑定。阅读现有的帖子,我发现了很多类似的问题。但我有两个问题。(1) 我找不到冲突依赖。(2) 我与gradle syntaxt不太相似。所以我尝试了很多方法。但还是很困惑。欢迎任何帮助。谢谢以下是错误: SLF4J:类路径包含多个SLF4J绑定 SLF4j:在[jar:file:/C:/myproject/gradle-2.3-all/gradle-2.3/lib/logback-classic-1.0.13.jar!/org/SLF4j/impl/StatLoggerBinder.class]中找到绑定 SLF4j:在[jar:file:/C:/myproject/myproject/build/temp/tomcatRunWar/work/Tomcat/localhost/myproject/WEB-INF/lib/logback-classic-1.1.2.jar!/org/SLF4j/impl/StatLoggerBinder.class]中找到绑定 SLF4j:实际绑定的类型为[ch.qos.logback.classic.util.ContextSelectorStaticBinder] 以下是我的从属关系:Java SLF4J:类路径包含多个SLF4J绑定。多个logback经典jar,java,spring,jar,Java,Spring,Jar,我正在使用gradle构建并运行SpringWeb应用程序。有多个绑定。阅读现有的帖子,我发现了很多类似的问题。但我有两个问题。(1) 我找不到冲突依赖。(2) 我与gradle syntaxt不太相似。所以我尝试了很多方法。但还是很困惑。欢迎任何帮助。谢谢以下是错误: SLF4J:类路径包含多个SLF4J绑定 SLF4j:在[jar:file:/C:/myproject/gradle-2.3-all/gradle-2.3/lib/logback-classic-1.0.13.jar!/org/
buildscript {
repositories {
maven { url "http://repo.spring.io/libs-release" }
mavenLocal()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:1.0.1.RELEASE")
classpath 'org.gradle.api.plugins:gradle-tomcat-plugin:1.2.4'
}}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'spring-boot'
apply plugin: 'war'
apply plugin: 'groovy'
apply plugin: 'tomcat'
eclipse {
jdt {
sourceCompatibility = 1.8
targetCompatibility = 1.8
}}
jar {
baseName = 'myproject'
version = '0.1.0' }
repositories {
mavenCentral()
maven { url "http://repo.spring.io/libs-release" } }
dependencies {
compile('commons-fileupload:commons-fileupload:1.3.1')
compile("org.codehaus.jackson:jackson-mapper-asl:1.9.0")
compile("org.springframework.boot:spring-boot-starter-web")
compile("org.springframework.data:spring-data-mongodb")
compile("org.springframework.security:spring-security-crypto:3.2.3.RELEASE")
compile("com.fasterxml.jackson.core:jackson-databind")
compile("joda-time:joda-time:2.2")
compile("org.apache.directory.studio:org.apache.commons.codec:1.6")
compile('com.amazonaws:aws-java-sdk:1.2.1')
testCompile("junit:junit")
runtime 'javax.servlet:jstl:1.2'
providedCompile group:"org.apache.tomcat", name:"tomcat-catalina", version:"7.0.47" }
dependencies {
def tomcatVersion = '7.0.47'
tomcat "org.apache.tomcat.embed:tomcat-embed-core:${tomcatVersion}",
"org.apache.tomcat.embed:tomcat-embed-logging-log4j:${tomcatVersion}"
tomcat("org.apache.tomcat.embed:tomcat-embed-jasper:${tomcatVersion}") {
exclude group: 'org.eclipse.jdt.core.compiler', module: 'ecj'
} }
tomcatRun { daemon = true
httpPort = 8080
outputFile = file('/logs/tomcat.log')
stopKey = 'ctl-d'
webDefaultXml = file('src/main/webapp/WEB-INF/web.xml') }
tomcatRunWar { outputFile = file('/logs/tomcat.log') }
tomcatStop { stopKey = 'ctl-d' }
首先在命令行上执行此操作:
gradle dependencies > foo.txt
当它完成的时候去喝咖啡。生成的文件将包含完整的依赖关系树。搜索logback
然后,当您修改构建文件时,据我所知(我在gradle也是比较新的),您只需要排除模块或组,而不是两者。组基本上是冒号前的部分,模块是冒号后的部分
再次查看错误的详细信息,我认为问题可能包含在这里:
"org.apache.tomcat.embed:tomcat-embed-logging-log4j:${tomcatVersion}"
因此,我认为您可能应该将其分解为自己的行/依赖项,并将exclude放在那里