无法使用Maven编译简单的Java 10 / Java 11项目

问题描述 投票:101回答:5

我有一个简单的Maven项目:

src
└── main
    └── java
        └── module-info.java
pom.xml

pom.hml:

<groupId>org.example</groupId>
<artifactId>example</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>example</name>

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.7.0</version>
            <configuration>
                <release>10</release>
            </configuration>
        </plugin>
    </plugins>
</build>

当我通过mvn -X install -DskipTests=true构建项目时,它失败了:

org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:testCompile (default-testCompile) on project example: Execution default-testCompile of goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:testCompile failed.
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:213)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:154)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:146)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:117)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:81)
        at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51)
        at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:128)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:309)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:194)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:107)
        at org.apache.maven.cli.MavenCli.execute(MavenCli.java:993)
        at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:345)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:191)
        at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.base/java.lang.reflect.Method.invoke(Method.java:564)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
        at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
        at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: org.apache.maven.plugin.PluginExecutionException: Execution default-testCompile of goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:testCompile failed.
        at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:145)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
        ... 20 more
Caused by: java.lang.IllegalArgumentException
        at org.objectweb.asm.ClassReader.<init>(Unknown Source)
        at org.objectweb.asm.ClassReader.<init>(Unknown Source)
        at org.objectweb.asm.ClassReader.<init>(Unknown Source)
        at org.codehaus.plexus.languages.java.jpms.AsmModuleInfoParser.parse(AsmModuleInfoParser.java:80)
        at org.codehaus.plexus.languages.java.jpms.AsmModuleInfoParser.getModuleDescriptor(AsmModuleInfoParser.java:54)
        at org.codehaus.plexus.languages.java.jpms.LocationManager.resolvePaths(LocationManager.java:83)
        at org.apache.maven.plugin.compiler.TestCompilerMojo.preparePaths(TestCompilerMojo.java:281)
        at org.apache.maven.plugin.compiler.AbstractCompilerMojo.execute(AbstractCompilerMojo.java:762)
        at org.apache.maven.plugin.compiler.TestCompilerMojo.execute(TestCompilerMojo.java:176)
        at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:134)
        ... 21 more

有没有办法来解决这个问题?

java maven java-10 java-11 module-info
5个回答
123
投票

UPDATE

答案现在已经过时了。见this answer


maven-compiler-plugin依赖于旧版本的ASM,它不支持Java 10(和Java 11)。但是,可以明确指定正确的ASM版本:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.7.0</version>
    <configuration>
        <release>10</release>
    </configuration>
    <dependencies>
        <dependency>
            <groupId>org.ow2.asm</groupId>
            <artifactId>asm</artifactId>
            <version>6.2</version> <!-- Use newer version of ASM -->
        </dependency>
    </dependencies>
</plugin>

你可以在https://search.maven.org/search?q=g:org.ow2.asm%20AND%20a:asm&core=gav找到最新的


111
投票

或者,从2018年7月30日开始修复上述问题,可以将maven中使用的java版本配置为任何高达JDK / 11的版本,并使用maven-compiler-plugin:3.8.0指定9,10,11的版本,没有任何显式依赖项。

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.8.0</version>
    <configuration>
        <release>11</release>  <!--or <release>10</release>-->
    </configuration>
</plugin>

注意: - 此版本的源/目标的默认值已从1.5提升到1.6。 - release notes.


编辑[30.12.2018]

实际上,您可以在针对JDK / 12编译代码时使用相同版本的maven-compiler-plugin

更多细节和如何Compile a JDK12 preview feature with Maven的示例配置。


21
投票

将你的maven-compiler-plugin提升到3.8.0似乎是必要的,但还不够。如果您仍然遇到问题,那么如果从命令行运行,还应确保将JAVA_HOME环境变量设置为Java 10(或11)。 (您收到的错误消息不会告诉您。)或者,如果您是从IDE运行,则需要确保将其设置为使用当前的JDK运行maven。


3
投票

它可能不完全是同一个错误,但我有一个类似的错误。

检查Maven Java版本

由于Maven也在运行Java,因此请先检查运行Maven的版本:

mvn --version | grep Java 

它返回:

Java版本1.8.0_151,供应商:Oracle Corporation,运行时:C:\ tools \ jdk \ openjdk1.8

不兼容的版本

上面我的maven正在与Java Version 1.8.0_151一起运行。所以即使我指定maven用Java 11编译:

<properties>
    <java.version>11</java.version>
    <maven.compiler.source>${java.version}</maven.compiler.source>
    <maven.compiler.target>${java.version}</maven.compiler.target>
</properties>

它会在逻辑上打印出这个错误:

[错误]无法执行目标org.apache.maven.plugins:maven-compiler-plugin:3.8.0:在项目上编译(default-compile)efa-example-commons-task:致命错误编译:无效目标版本:11 - > [帮助1]

如何将特定的Java版本设置为Maven

合乎逻辑的做法是将更高的Java版本设置为Maven(例如Java版本11而不是1.8版本)。

Maven利用环境变量JAVA_HOME来查找要运行的Java版本。因此,将此变量更改为要编译的JDK(例如OpenJDK 11)。

完整性检查

然后再次运行mvn --version以确保配置已被处理:

λmvn--version | grep Java Java版本:11.0.2,供应商:Oracle Corporation,运行时:C:\ tools \ jdk \ openjdk11

编译使用Java 11规范编写的代码更好,更正确。


1
投票

指定maven.compiler.source和目标版本。

1)支持你使用的jdk的Maven版本。在我的情况下JDK 11和maven 3.6.0。

2)Pom.hml

<properties>
    <maven.compiler.source>11</maven.compiler.source>
    <maven.compiler.target>11</maven.compiler.target>
</properties>

作为替代方案,您可以完全指定maven编译器插件。见前面的答案。它在我的例子中更短:)

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.0</version>
            <configuration>
                <release>11</release>
            </configuration>
        </plugin>
    </plugins>
</build>

3)重建项目以避免IDE中的编译错误。

4)如果仍然不起作用。在Intellij Idea中,我更喜欢使用终端而不是使用OS中的终端。然后在Idea中转到文件 - >设置 - >构建工具 - > maven。我使用从apache下载的maven(默认情况下使用捆绑的maven)。然后重新启动Idea并再次运行mvn clean install。还要确保您具有正确的Path,MAVEN_HOME,JAVA_HOME环境变量。

我也看到了这个单行,但它不起作用。

<maven.compiler.release>11</maven.compiler.release>
© www.soinside.com 2019 - 2024. All rights reserved.