Java SLF4J:类路径包含多个SLF4J绑定。多个logback经典jar

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/

我正在使用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]

以下是我的从属关系:

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放在那里