4

im already set the build path for log4j12-api-beta2.jar but it gives the following error please help me to solve this problem
my code is follows java file:

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;
}



 }

and my Main() file is:

 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());

}

}

it gives the following Exception:

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
4

3 回答 3

2

我刚刚从这里下载了 log4j 2.0:http: //logging.apache.org/log4j/2.x/download.html

我还没有使用它,但看起来你可能既需要在类路径上log4j-api-2.0-beta2.jar也需要log4j-core-2.0-beta2.jar。我猜api jar是这样你可以编译的,核心包含实现。

于 2012-11-09T13:29:28.153 回答
0

您是否在使用 IDE(例如 Eclipse)并且您是否通过运行代码(而不是在编译代码时)获得了堆栈跟踪?

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

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

于 2015-12-30T04:40:07.587 回答
-5

文基马华,

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

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

他们会很好地工作。

于 2013-01-08T12:10:50.040 回答