2

我正在构建一个使用 maven 进行依赖管理的新 Spring Web 应用程序。我正在尝试使用 slf4j-api 和 slf4j-simple。我将它们添加到我的 pom 文件中,但是当我构建时出现错误

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.

这表明 slf4j 没有实现,但是,slf4j-simple 包含在我的 pom.xml 中。下面是我的 pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>foo.bar</groupId>
  <artifactId>name</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>war</packaging>
  <name>name</name>


    <properties>
        <org.springframework.version>3.1.0.RELEASE</org.springframework.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${org.springframework.version}</version>
             <exclusions>
                  <exclusion>
                      <groupId>commons-logging</groupId>
                      <artifactId>commons-logging</artifactId>
                  </exclusion>
             </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${org.springframework.version}</version>
        </dependency>
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
             <version>3.6.3.Final</version>
        </dependency>
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.6.6</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.6.6</version>
        </dependency>
        <dependency>
            <groupId>net.sourceforge.jtds</groupId>
            <artifactId>jtds</artifactId>
            <version>1.2.4</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>ROOT</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.5.1</version>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                </configuration>
            </plugin>
            <plugin>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.1.1</version>
                <configuration>
                    <packagingExcludes>WEB-INF/web.xml</packagingExcludes>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>    

下面是我的 Maven 依赖树:

[INFO] foo.bar:name:war:0.0.1-SNAPSHOT
[INFO] +- org.springframework:spring-context:jar:3.1.0.RELEASE:compile
[INFO] |  +- org.springframework:spring-aop:jar:3.1.0.RELEASE:compile
[INFO] |  |  \- aopalliance:aopalliance:jar:1.0:compile
[INFO] |  +- org.springframework:spring-beans:jar:3.1.0.RELEASE:compile
[INFO] |  +- org.springframework:spring-core:jar:3.1.0.RELEASE:compile
[INFO] |  +- org.springframework:spring-expression:jar:3.1.0.RELEASE:compile
[INFO] |  \- org.springframework:spring-asm:jar:3.1.0.RELEASE:compile
[INFO] +- org.springframework:spring-webmvc:jar:3.1.0.RELEASE:compile
[INFO] |  +- org.springframework:spring-context-support:jar:3.1.0.RELEASE:compile
[INFO] |  \- org.springframework:spring-web:jar:3.1.0.RELEASE:compile
[INFO] +- jstl:jstl:jar:1.2:compile
[INFO] +- org.hibernate:hibernate-core:jar:3.6.3.Final:compile
[INFO] |  +- antlr:antlr:jar:2.7.6:compile
[INFO] |  +- commons-collections:commons-collections:jar:3.1:compile
[INFO] |  +- dom4j:dom4j:jar:1.6.1:compile
[INFO] |  +- org.hibernate:hibernate-commons-annotations:jar:3.2.0.Final:compile
[INFO] |  +- org.hibernate.javax.persistence:hibernate-jpa-2.0-api:jar:1.0.0.Final:compile
[INFO] |  \- javax.transaction:jta:jar:1.1:compile
[INFO] +- org.slf4j:slf4j-api:jar:1.6.6:compile
[INFO] +- org.slf4j:slf4j-simple:jar:1.6.6:compile
[INFO] \- net.sourceforge.jtds:jtds:jar:1.2.4:compile

关于什么可能是错误的任何想法?谢谢。

4

5 回答 5

3

我遇到了类似的问题。更糟糕的是,Hibernate 没有显示异常的完整堆栈跟踪。

我正在使用 Eclipse Luna 并且正在开发一个 Maven 项目。

在阅读了与上述问题有关的各种答案后,在我使用之前没有任何帮助:' Slf4j Maven Plugin Log ':

“一个委托给 maven-plugin 日志工具包的 SLF4J 实现。当 maven-plugin 依赖项使用 slf4j 时特别有用,因为它们的日志不能作为 maven-plugin 日志使用。”

来源: http: //mvnrepository.com/artifact/com.googlecode.slf4j-maven-plugin-log/slf4j-maven-plugin-log/1.0.0

于 2015-08-23T15:51:16.457 回答
2

显然这是 m2eclipse 插件中的一个错误。

SLF4J:无法加载类“org.slf4j.impl.StaticLoggerBinder”。错误

https://bugs.eclipse.org/bugs/show_bug.cgi?id=387064

于 2012-10-10T03:07:21.397 回答
1

今天早些时候在我寻找答案时发现了这个。不久之后,我终于找到了对我有用的答案。Spring在幕后记录中为我回答了这个问题

它的要点是将以下内容添加到您的 pom.xml 中:

<dependency> 
 <groupId>org.apache.logging.log4j</groupId>
 <artifactId>log4j-slf4j-impl</artifactId>
 <version>2.1</version>
</dependency> 
于 2014-10-26T02:41:32.860 回答
0

我们对 log4j jars 也有类似的问题。

  CLASSPATH="default/lib/log4j-1.2.16.jar"
  CLASSPATH="$CLASSPATH:$JAVA_CLASSPATH:$APP_CLASSPATH"

已添加到启动脚本中以使其首先被拾取。原来我们是从父模块继承另一个版本的 jar

于 2012-10-09T10:07:43.497 回答
0

我在我的环境中尝试了您的确切 POM,一切正常 - 没有错误。这让我相信它是你的环境。它肯定会注意 POM,因为您的 WAR 文件已正确创建。所以你可以看看其他一些东西:

  1. 你确定你在类路径上没有不同版本的 SLF4J 吗?Maven 在构建时倾向于只选择一个,因此可能会导致问题。
  2. 我以前没有使用过 Spring Tool Suite (STS),但也许这会导致您的问题,您是否尝试过mvn clean package在命令行上运行?我知道我以前在 Eclipse 中看到过类似这样的问题,我们在类路径上有另一个版本的 SLF4J,并且在 Eclipse 中构建时 mvn 会失败。
于 2012-10-09T09:22:48.283 回答