我已经为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
答案 0 :(得分:1)
我刚从这里下载了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是你可以编译的,核心包含实现。
答案 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;
他们会工作得很好。