0

私のメインクラスはSettings.javaクラスを参照し、新しいプロパティを参照せずにmavenを実行すると、うまく動作します:

mvn assembly:assembly

新しいプロパティを参照すると、次のエラーが発生します。

[ERROR] /Users/.../service.java:[41,58] cannot find symbol
[ERROR] symbol  : method getDefaultScore()

これはマルチ Maven プロジェクトです。依存関係は、別の Maven モジュールであるローカル依存関係であるため、この新しいプロパティを取得しない理由がわかりません。

mvn cleanキャッシュされた場合に備えて、ルートで実行しました。

注: このアプリケーションは、IntelliJ 経由でビルドして実行すると正常に動作しますが、maven を使用すると、この新しいプロパティが気に入らないようです (これは単に、割り当てた値を返す文字列プロパティではなく、そうではありません)。プロパティファイルなどからの読み取り)。

デバッグで実行する場合:

mvn assembly:assembly -X

同じ「シンボルが見つかりません」というメッセージが表示され、場所は他のmavenモジュールのクラスであり、次のようになります。

org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.3.2:compile (default-compile) on project myapp-jobs: Compilation failure
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:213)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
    at org.apache.maven.lifecycle.internal.MojoExecutor.executeForkedExecutions(MojoExecutor.java:365)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:199)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
    at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
    at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
    at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:319)
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
    at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537)
    at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196)
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)
Caused by: org.apache.maven.plugin.CompilationFailureException: Compilation failure
    at org.apache.maven.plugin.AbstractCompilerMojo.execute(AbstractCompilerMojo.java:656)
    at org.apache.maven.plugin.CompilerMojo.execute(CompilerMojo.java:128)
    at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209)
    ... 23 more

念のため、新しいプロパティの参照を古いプロパティに置き換えたところ、mvn コマンドは問題なく実行されたので、def です。新しいプロパティに問題があります。これは単に次のとおりです。

public class Settings {
..
..
private String defaultScore = "100";

  public String getDefaultScore() {
        return defaultScore;
    }

}

私のコンピューター/Mavenのバージョンなど:

  • Apache Maven 3.0.3 (r1075438; 2011-02-28 12:31:09-0500)
  • Maven ホーム: /Users/../java/apache-maven-3.0.3
  • Java バージョン: 1.6.0_31、ベンダー: Apple Inc.
  • Java ホーム: /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home
  • デフォルトのロケール: en_US、プラットフォームのエンコード: MacRoman
  • OS 名:「mac os x」、バージョン:「10.7.4」、アーキテクチャ:「x86_64」、ファミリ:「mac」
4

2 に答える 2

3

新しいプロパティを追加した依存関係プロジェクトの正しいバージョンを使用していることを確認してください。このプロジェクトのバージョンが1.0.0-SNAPSHOTの場合 (スナップショット バージョンですよね?)、プロパティを表示するプロジェクトでこのバージョンを参照してください。

バージョンが確認されたら、mvn clean installルートで a を実行して、すべての依存関係を再構築します。

それでもうまくいかない場合は、ローカルの Maven リポジトリ ( ~/.m2) を調べて、依存関係の JAR ファイルにクラスの最新バージョンが含まれていることを確認してください。

于 2012-06-18T06:19:55.927 に答える
0

mvn install最初のモジュールで実行してみましたか?

于 2012-06-18T04:39:28.877 に答える