eclipse ide を使用して Java で簡単なプロジェクトを作成し、log4j 機能をテストしました。Java の jar ツールを使用して、コマンド プロンプトからアプリケーションを実行する必要があります。logtest.java ファイルは、以下のようにロガーを定義する単純な Java ファイルです。別の Jar ファイルにあるロガーを参照しています。以下はディレクトリ構造です。
package com;
import org.apache.log4j.Logger;
public class logtest {
private static Logger logger = Logger.getLogger(logtest.class);
public static void main(String[] args) {
System.out.println("---------------HIIIIII-----------");
}
以下は、Eclipse のプロジェクトで作成したディレクトリ構造です。
src/com/logtest.java
lib/log4j-1.2.17.jar
マニフェスト ファイルのエントリは以下のとおりで、手動で maifest ファイルを作成しました。
Manifest-Version: 1.0
Main-Class: com.logtest
Class-Path: lib/log4j-1.2.17.jar
Jarファイルの内容は以下のとおりで、jarユーティリティを使用して解凍しました。
META-INF/MANIFEST.MF
.project
com/logtest.class
manifest.mf
lib/log4j-1.2.17.jar
.classpath
jar ファイルをエクスポートしました。commond java -jar JarTest2.jar を使用して実行しようとすると、次のエラーが発生します。
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
at com.logtest.<clinit>(logtest.java:6)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
at java.net.URLClassLoader$1.run(Unknown Source)
at java.net.URLClassLoader$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
... 1 more
クラスが見つからない例外であることは知っていますが、jdk1.5を使用して作成し、コマンドツールを実行すると、同じjarが正常に実行され、Javaクラスがエラーなしで実行されるという奇妙なことがあります。
すべてが同じなので、なぜこれが起こっているのかわかりません。
私のは64ビットのWindows 7マシンで、それが実行されている他のマシンは32ビットのXPマシンです。
もちろん、Eclipse ide のバージョンは両方のマシンで異なります。
私がやっていることに何か問題があるのか 、それとも他に何か欠けているのか教えてください.
ありがとう