在Log4j 2.0中找到ClassNotFoundException

时间:2012-11-09 13:15:52

标签: java log4j

我已经为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 个答案:

答案 0 :(得分:1)

我刚从这里下载了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是你可以编译的,核心包含实现。

答案 1 :(得分:0)

您使用的是IDE(例如Eclipse)吗?您是否通过运行代码而不是编译代码来获取堆栈跟踪?

这里只是一个疯狂的猜测,但你可能只是设置构建路径(所以你的项目编译好了),但是在运行时你的类路径没有Log4J罐。

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

答案 2 :(得分:-5)

VenkyMCA,

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

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

他们会工作得很好。