0

Ant を使用するのは初めてでjava.lang.NoClassDefFoundError、実行しようとすると例外が発生します。これが私のAntビルドスクリプトです。

<project name="LearnKirtan" basedir="." default="main">

    <property name="src.dir" value="src" />
    <property name="lib.dir" value="lib" />

    <property name="build.dir" value="build" />
    <property name="classes.dir" value="${build.dir}/classes" />
    <property name="jar.dir" value="${build.dir}/jar" />

    <path id="classpath">
        <fileset dir="${lib.dir}" includes="**/*.jar" />
    </path>

    <property name="main-class" value="gsingh.learnkirtan.Main" />

    <target name="clean">
        <delete dir="${build.dir}" />
    </target>

    <target name="compile">
        <mkdir dir="${classes.dir}" />
        <javac srcdir="${src.dir}" destdir="${classes.dir}" includeantruntime="false" classpathref="classpath" />
    </target>

    <target name="jar" depends="compile">
        <mkdir dir="${jar.dir}" />
        <jar destfile="${jar.dir}/${ant.project.name}.jar" basedir="${classes.dir}">
            <manifest>
                <attribute name="Main-Class" value="${main-class}" />
            </manifest>
        </jar>
    </target>

    <target name="run" depends="jar">
        <java classname="${main-class}" fork="true" />
        <classpath>
            <path refid="classpath" />
            <path location="${jar.dir}/${ant.project.name}.jar" />
        </classpath>
    </target>

    <target name="clean-build" depends="clean,jar" />

    <target name="main" depends="clean,run" />

</project>

ビルドにエラーはありません。実行ターゲットは例外を与えます。jarファイルで生成されたマニフェストを確認したところ、次のようになっています。

Manifest-Version: 1.0
Ant-Version: Apache Ant 1.8.2
Created-By: 1.6.0_30-b12 (Sun Microsystems Inc.)
Main-Class: gsingh.learnkirtan.Main
4

4 に答える 4

4

実行ターゲットは少し不安定に見えます。これ<java classname="${main-class}" fork="true" />は自己終了であるため、classpath要素は使用されません

<target name="run" depends="jar">
    <java classname="${main-class}" fork="true" >
        <classpath>
            <path refid="classpath" />
            <path location="${jar.dir}/${ant.project.name}.jar" />
        </classpath>
    </java>
</target>

あなたのために働くかもしれません。

于 2012-04-30T21:02:28.357 に答える
1

問題は、タスクのクラスパスをjava正しく指定していないことです。

これを試して:

<java classname="${main-class}" fork="true">
    <classpath>
        <path refid="classpath" />
        <path location="${jar.dir}/${ant.project.name}.jar" />
    </classpath>
</java>
于 2012-04-30T21:04:07.833 に答える
0

そしてついに決定事項が判明!スクリプトを次のように書き直しました。

 <path id="master-classpath">
    <fileset dir="${tomcat.home}/webapps/${project.war}-admin/WEB-INF/lib">
       <include name="*.jar"/>
    </fileset>

    <fileset dir="${workspace.path}/artifacts">
       <include name="${jar_name}"/>
    </fileset>

    <fileset dir="${workspace.path}/deploy_scripts/libs/app">
       <include name="${jdbc_jar_name}"/>
    </fileset>
  </path>
  <java classname="com.${company}.${project}.scheduler.SchedulerManager" fork="true">
      <jvmarg value="-Ddb.username=${db.user}"/>
      <jvmarg value="-Ddb.password=${db.password}"/>
      <jvmarg value="-Ddb.url=${db.url}"/>

      <classpath refid="master-classpath"/>
  </java>
于 2013-01-18T13:31:48.683 に答える
0

そして、私には問題がありそうです。私のスクリプトは次のとおりです。

<java classname="SchedulerManager" fork="true">
          <jvmarg value="-Ddb.username=${db.user}"/>
          <jvmarg value="-Ddb.password=${db.password}"/>
          <jvmarg value="-Ddb.url=${db.url}"/>

          <classpath>
             <pathelement location="${tomcat.home}/webapps/${project.war}-admin/WEB-INF/lib/${jar_name}"/>
             <pathelement path="com.${company}.${project}.scheduler.SchedulerManager"/>
          </classpath>
      </java>

実行すると、次のエラーが表示されます。

 [java] Exception in thread "main" java.lang.NoClassDefFoundError: com/<company>/<project>/scheduler/SchedulerManager
 [java] Caused by: java.lang.ClassNotFoundException: com.<company>.<project>.scheduler.SchedulerManager
 [java]     at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
 [java]     at java.security.AccessController.doPrivileged(Native Method)
 [java]     at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
 [java]     at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
 [java]     at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
 [java]     at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
 [java] Could not find the main class: com.<company>.<project>.scheduler.SchedulerManager.  Program will exit.
 [java] Java Result: 1

しかし、フォルダ " " に CD を作成して${tomcat.home}/webapps/${project.war}-admin/WEB-INF/lib/実行すると、次のようになります。

java -cp "*" -Ddb.username=${db.user} -Ddb.password=${db.password} -Ddb.url=${db.url} com.<company>.<project>.scheduler.SchedulerManager (of course I gave real parameters)

出来た!

于 2013-01-18T06:50:25.830 に答える