Log4j 2.0 中发现 ClassNotFoundException。

4

我已经设置了log4j12-api-beta2.jar的构建路径,但它仍然给出以下错误,请帮助我解决这个问题。
我的代码如下: Java文件:

package com.sst.log4j;

 class Product {
private int productId;
private String productName;
public int getProductId() {
    return productId;
}
public void setProductId(int productId) {
    this.productId = productId;
}
public String getProductName() {
    return productName;
}
public void setProductName(String productName) {
    this.productName = productName;
}
public Product(int productId, String productName) {
    super();
    this.productId = productId;
    this.productName = productName;
}



 }

我的Main()文件如下:

 package com.sst.log4j;
import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;

public class ProductMain {

/**
 * @param args
 */
static Logger log=LogManager.getLogger(Product.class.getName());
public static void main(String[] args) {
    // TODO Auto-generated method stub
    Product p1=new Product(1,"garlands");
    System.out.println(p1.getProductName());
    log.error(p1.getProductName());

}

}

出现以下异常:

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/logging/
 log4j/LogManager
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:791)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at org.apache.log4j.LogManager.getLogger(LogManager.java:38)
at com.sst.log4j.ProductMain.main(ProductMain.java:14)
    Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
  at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
... 14 more
3个回答

2
我刚刚从这里下载了log4j 2.0:http://logging.apache.org/log4j/2.x/download.html 虽然我还没有使用它,但看起来你可能需要在类路径上同时使用log4j-api-2.0-beta2.jarlog4j-core-2.0-beta2.jar。我猜测api jar是为了编译,而core则包含实现。

0

你是否在使用IDE(例如Eclipse),并且是在运行代码时获取堆栈跟踪(而不是编译代码时)?

这只是一个猜测,但你可能只是设置了构建路径(以便项目可以编译通过),但是在运行时,你的类路径中没有Log4J的jar包。

在Eclipse中,你可以导出一个JAR文件,以便在运行时可用。


-5

VenkyMCA,

您需要导入以下包才能使用log4j 2.0:

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

它们将正常工作。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接