LocationAwareLogger 上的 SLF4J NoSuchMethodError

Posted

技术标签:

【中文标题】LocationAwareLogger 上的 SLF4J NoSuchMethodError【英文标题】:SLF4J NoSuchMethodError on LocationAwareLogger 【发布时间】:2012-01-05 08:37:33 【问题描述】:

这是一个以前被问过的问题,但不幸的是,似乎没有任何解决方案对我有用。我正面临这个异常(带有删节的堆栈跟踪):

java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;[Ljava/lang/Object;Ljava/lang/Throwable;)V
    at org.apache.commons.logging.impl.SLF4JLocationAwareLog.debug(SLF4JLocationAwareLog.java:133)
    at org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager$1.getConnection(ThreadSafeClientConnManager.java:221)
    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:401)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:820)

在使用命令行 Maven 编译以及部署到 Tomcat 时会发生这种情况。它在 IntelliJ IDEA 中运行良好。

通常我认为这是由多个版本的 SLF4J 库正在使用引起的。但是 Maven 依赖树在单个版本中显示了所有 slf4j 库:

..$ mvn dependency:tree | grep slf4j
[INFO] +- org.slf4j:slf4j-simple:jar:1.6.4:compile
[INFO] |  \- org.slf4j:slf4j-api:jar:1.6.4:compile
[INFO] +- org.slf4j:slf4j-api:jar:1.6.4:compile
[INFO] +- org.slf4j:jcl-over-slf4j:jar:1.6.4:compile
[INFO] +- org.slf4j:slf4j-simple:jar:1.6.4:compile

我什至确保 ~/.m2/repository 中没有其他 JAR

也没有对公共日志库的引用(我将它们全部排除在依赖树中。

我该如何解决这个问题?我的想法不多了。

编辑:这里要求完整的依赖关系,首先是父 POM:

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>$org.hibernate.validator.version</version>
            <exclusions>
                <!-- Exclude SLF4j to avoid version conflicts (we have 1.6.2, this drags in 1.6.1) -->
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-api</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator-annotation-processor</artifactId>
            <version>$org.hibernate.validator.version</version>
        </dependency>

        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.0.0.GA</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>$org.springframework.version</version>
            <exclusions>
                <!-- Exclude Commons Logging in favor of SLF4j -->
                <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>org.springframework.security</groupId>
            <artifactId>spring-security-config</artifactId>
            <version>$org.springframework.version</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-core</artifactId>
            <version>$org.springframework.version</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-web</artifactId>
            <version>$org.springframework.version</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-taglibs</artifactId>
            <version>$org.springframework.version</version>
        </dependency>
        <dependency>
            <groupId>javax.inject</groupId>
            <artifactId>javax.inject</artifactId>
            <version>1</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.8.2</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>$org.slf4j.backend</artifactId>
            <version>$org.slf4j.version</version>
        </dependency>
        <dependency>
            <groupId>org.hsqldb</groupId>
            <artifactId>hsqldb</artifactId>
            <version>2.2.4</version>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.0</version>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time-jsptags</artifactId>
            <version>1.0.2</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.1</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.0-801.jdbc4</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.0.1</version>
        </dependency>
    </dependencies>
</dependencyManagement>

然后是失败的模块:

<dependencies>
    // client specific dependencies skipped //

    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>10.0.1</version>
    </dependency>

    <!-- Spring -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <exclusions>
            <!-- Exclude Commons Logging in favor of SLF4j -->
            <exclusion>
                <groupId>commons-logging</groupId>
                <artifactId>commons-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-config</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-core</artifactId>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-web</artifactId>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-taglibs</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>javax.inject</groupId>
        <artifactId>javax.inject</artifactId>
    </dependency>
    <dependency>
        <groupId>cglib</groupId>
        <artifactId>cglib</artifactId>
        <version>2.2.2</version>
    </dependency>

    <!-- Logging -->
    <dependency>
        <groupId>net.sf.opencsv</groupId>
        <artifactId>opencsv</artifactId>
        <version>2.0</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>$org.slf4j.version</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jcl-over-slf4j</artifactId>
        <version>$org.slf4j.version</version>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>$org.slf4j.backend</artifactId>
        <version>$org.slf4j.version</version>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.16</version>
    </dependency>

    <!-- Joda Time -->
    <dependency>
        <groupId>joda-time</groupId>
        <artifactId>joda-time</artifactId>
    </dependency>
    <dependency>
        <groupId>joda-time</groupId>
        <artifactId>joda-time-jsptags</artifactId>
        <scope>runtime</scope>
    </dependency>

    <!-- Servlet -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
    </dependency>
    <dependency>
        <groupId>com.google.visualization</groupId>
        <artifactId>visualization-datasource</artifactId>
        <version>1.0.2</version>
    </dependency>

    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.0.2</version>
    </dependency>
    <dependency>
        <groupId>commons-dbcp</groupId>
        <artifactId>commons-dbcp</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>org.codehaus.jackson</groupId>
        <artifactId>jackson-mapper-asl</artifactId>
        <version>1.9.0</version>
    </dependency>
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.1</version>
    </dependency>
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.2.2</version>
    </dependency>

    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.7</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.7</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml-schemas</artifactId>
        <version>3.7</version>
    </dependency>

    <dependency>
        <groupId>postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <scope>runtime</scope>
    </dependency>

    <dependency>
        <scope>test</scope>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
    </dependency>
</dependencies>

这些是在父级上设置的属性:

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <org.hibernate.validator.version>4.2.0.Final</org.hibernate.validator.version>
    <org.slf4j.backend>slf4j-simple</org.slf4j.backend>
    <org.slf4j.version>1.6.4</org.slf4j.version>
    <org.springframework.version>3.0.5.RELEASE</org.springframework.version>
</properties>

不过,鉴于我最近的实验,这似乎不是与项目文件有关的问题。我试图将问题“平分”,但回溯数周后,我找不到有效的版本。其中一些正在生产系统中运行,因此不太可能是代码更改导致此问题。

【问题讨论】:

你能分享你 pom.xml 的依赖吗? 【参考方案1】:

NoSuchMethodError 的 javadocs 说,

通常,编译器会捕获此错误;这个错误可以 仅当类的定义发生不兼容的更改时才会在运行时发生。

所以这可能是由于加载的 slf4j 版本不兼容造成的。与其查看您的类路径并猜测类的加载位置,不如按照here 的描述找到您的类的加载位置。

打印出 org.slf4j.spi.LocationAwareLoggerorg.apache.commons.logging.impl.SLF4JLocationAwareLogorg.slf4j.Marker 的加载位置。

【讨论】:

我应该考虑询问类加载器。事实证明auskey.abr.gov.au 是罪魁祸首:当我 5 天前安装他们的密钥时,他们将 1.5.8 slf4j 的副本转储到 /usr/java/packages/lib/ext/ 中。那里有更多可怕的东西(log4j、bcmail、jaxb...)——我需要设置一个单独的 JRE。不过,我希望 slf4j 停止破坏二进制兼容性。 安装auskey后正好遇到这个问题!感谢@PeterBecker 的评论。 我可以导入这个答案中提到的类(因为在 IDE 中不会抱怨找不到它们),但是当我尝试运行应该显示它们的代码时从中加载,我得到一个编译错误:package does not existcannot find symbol。然而slf4j 在我的类路径中,而且只有一个版本。 @payne 我会使用干净的 JRE(已经有一段时间了),但这是一个与您不同的问题。您可能依赖于 IDE 的库集,而不是运行时类路径。它可能需要自己的问题。【参考方案2】:

我收到了相同的错误消息,但解决方案对我来说不同。我必须 删除 以遵循 maven pom 的依赖项:

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>jcl-over-slf4j</artifactId>
  <version>1.6.1</version>
</dependency>

之后错误消失了,一切都对我有用。

【讨论】:

我在父 pom 中将其添加为 provided 依赖项 如果它一开始就在那里,那可能是有原因的?【参考方案3】:

一个解决方案。

在eclipse目录上验证:configuration\org.eclipse.equinox.simpleconfigurator\bundles.info

slf4j 没有了

【讨论】:

【参考方案4】:

mvn clean 依赖:tree -DskipTests;

删除“org.slf4j”的所有依赖项,除了一个(最高的一个“)为

    <dependency>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-jar-plugin</artifactId>
        <version>2.6</version>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-jdk14</artifactId>
            </exclusion>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>jcl-over-slf4j</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

【讨论】:

【参考方案5】:

我们遇到了类似的问题,结果我们在类路径中有 2 个不兼容的 slf4j jar 版本。 类路径有以下 2 个不兼容的版本。从类路径中删除较低版本后,问题得到解决。

slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar

slf4j-api-1.5.11.jar slf4j-log4j12-1.5.11.jar

【讨论】:

【参考方案6】:

解决了!!!

我依赖于另一个使用 JavaDoc 插件的项目。 JavaDoc 插件内部使用Maven-coreMaven-core-2.2.1 使用jcl-over-slf4j: 1.5.6Maven-core 是父级 jar。

现在,由于这个JCL jar,我遇到了这个问题。 因此,我将其从weblogic(或您可能使用的任何服务器)的lib 文件夹中删除。

唉!问题已解决。

注意 1:- 您也可以使用 Maven 的 &lt;exclusion&gt; 标签从 JavaDoc(或任何其他插件)中删除此依赖项以解决此问题。

注意 2:- 使用 POM 中的 Dependency Hierarchy 选项卡查看是否存在任何此类旧的 SLF4J jar。并去掉其余部分,只保留一个版本。

希望对您有所帮助..

【讨论】:

【参考方案7】:

当您的依赖项都使用相同的传递依赖项时,通常会发生这种情况。这意味着您的两个依赖项(或您的应用程序和传递依赖项)都在内部使用不同版本的 SLF4J。但是你的应用只能同时使用一个版本的类,所以它必须选择(不知道这里的规则......随机?)

要解决这个问题,你通常需要做一个mvn dependency:tree 来查看哪些使用不同版本的SLF4J。

添加此依赖项为我解决了问题

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.25</version>
</dependency>

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.5</version>
</dependency>

【讨论】:

【参考方案8】:

我的 pom 文件中有石英调度程序,其中包括 slf4j,所以我排除了它:

<exclusion>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
</exclusion>

并且工作了!

【讨论】:

以上是关于LocationAwareLogger 上的 SLF4J NoSuchMethodError的主要内容,如果未能解决你的问题,请参考以下文章

springMvc引入slf4j报错,org.slf4j.spi.LocationAwareLogger.log如何解决?

java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/Stri

Android 应用程序开发上的 SL4A 与 Ruboto

如何检测是不是使用 sl4a 按下了菜单按钮?

带有 qpython 的 web 应用程序和 android 中的 SL4A

我可以在 Android Market 上出售我的 SL4A 应用吗?