我有一个简单的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
有没有办法来解决这个问题?
答案现在已经过时了。见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找到最新的
或者,从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的示例配置。
将你的maven-compiler-plugin提升到3.8.0似乎是必要的,但还不够。如果您仍然遇到问题,那么如果从命令行运行,还应确保将JAVA_HOME环境变量设置为Java 10(或11)。 (您收到的错误消息不会告诉您。)或者,如果您是从IDE运行,则需要确保将其设置为使用当前的JDK运行maven。
它可能不完全是同一个错误,但我有一个类似的错误。
检查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规范编写的代码更好,更正确。
指定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>