尽管存在Maven依赖关系,但org.apache.log4j.Logger无法解析

Tom*_*Tom 3 java log4j maven-plugin maven

我正在使用maven(即Eclipse的maven插件)进行依赖项管理,并且通常可以正常工作。例如,jasypt可以解决强文本问题,并且我可以毫无问题地使用它。但是,当我尝试使用Log4J时,即使遵循了http://logging.apache.org/log4j/2.x/maven- artifacts.html

那里说我需要在我的pom.xml中包含以下代码段

<dependencies>
  <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.6.2</version>
  </dependency>
  <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.6.2</version>
  </dependency>
</dependencies>
Run Code Online (Sandbox Code Playgroud)

但是,正好包含在我的pom.xml中,如下文完整的pom.xml所示。这对任何人有意义吗?我也尝试用以下替换两个依赖项,但是没有成功

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>2.6.2</version>
    <type>pom</type>
</dependency>
Run Code Online (Sandbox Code Playgroud)

干杯汤姆

<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>PCenter</groupId>
  <artifactId>PCenter</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>war</packaging>
  <name>PCenter</name>
  <build>
    <sourceDirectory>src</sourceDirectory>
    <resources>
      <resource>
        <directory>src</directory>
        <excludes>
          <exclude>**/*.java</exclude>
        </excludes>
      </resource>
      <resource>
        <directory>ejbModule</directory>
        <excludes>
          <exclude>**/*.java</exclude>
        </excludes>
      </resource>
    </resources>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.5.1</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
      <plugin>
        <artifactId>maven-war-plugin</artifactId>
        <version>2.6</version>
        <configuration>
          <warSourceDirectory>WebContent</warSourceDirectory>
          <failOnMissingWebXml>false</failOnMissingWebXml>
        </configuration>
      </plugin>
    </plugins>
  </build>
  <dependencies>
    <dependency>
        <groupId>com.paypal.sdk</groupId>
        <artifactId>rest-api-sdk</artifactId>
        <version>1.9.2</version>
    </dependency>
    <dependency>
        <groupId>org.jasypt</groupId>
        <artifactId>jasypt</artifactId>
        <version>1.9.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.axis</groupId>
        <artifactId>axis</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>org.apache.axis</groupId>
        <artifactId>axis-jaxrpc</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.6.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.6.2</version>
    </dependency>
  </dependencies>
</project>
Run Code Online (Sandbox Code Playgroud)

ppe*_*rka 6

问题是您在依赖项中有Log4j2,并使用了较旧的Log4j 1.2.x API。

  • 要么依赖于Log4j 1.2.x

    <dependencies>
      <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
      </dependency>
    </dependencies>
    
    Run Code Online (Sandbox Code Playgroud)
  • 或对Log4j 2.x使用正确的API调用:

呼叫org.apache.log4j.Logger.getLogger()必须修改为org.apache.logging.log4j.LogManager.getLogger()

(从Log4j 1.x迁移


Art*_*s M 5

嗯,实际上我尝试了 ppeterkas 建议的解决方案,包括旧的 1.2x api,但这对我不起作用,我仍然遇到这个问题。由于无法编译的代码实际上并不是我的代码,而是我碰巧在自己的代码中使用的一些开源代码,所以我真的不想修改它的记录器(我还应该提到,我只是在新计算机上新打开我的 eclipse 之后,在它实际上使用相同的 pom.xml 进行良好编译之前,开始遇到这个问题,所以这很奇怪,但仍然需要修复...)。

因此,我的解决方案是包含 log4j 2.7 的 Apache Log4j 1.x 兼容性 API:

http://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-1.2-api/2.7

<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-1.2-api -->
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-1.2-api</artifactId>
    <version>2.7</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)

希望这能帮助其他遇到同样问题的人。