我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
这应该是java -jar app.jar而不是java -jar "app"。
只有当JAR文件是可执行JAR文件时,-jar选项才有效,这意味着它必须有一个带有Main-Class属性的清单文件。参见在JAR文件中打包程序以了解如何创建可执行JAR。
如果它不是一个可执行的JAR,那么你需要像这样运行程序:
java -cp app.jar com.somepackage.SomeClass
其中com.somepackage.SomeClass是包含运行程序的主方法的类。(这个类是什么取决于程序,不可能从您提供的信息中判断出来)。
首先,这有点奇怪,看到你运行java -jar "app"而不是java -jar app.jar
其次,要使jar可执行…你需要jar一个名为META-INF/MANIFEST的文件。曼氏金融
文件本身应该(至少)有这样一行:
Main-Class: com.mypackage.MyClass
其中com.mypackage.MyClass是持有公共静态void main(String[] args)入口点的类。
注意,有几种方法可以用CLI、Maven、Ant或Gradle来完成:
对于CLI,执行以下命令即可:(tks @dvvrt)
jar cmvf META-INF/MANIFEST.MF <new-jar-filename>.jar <files to include>
对于Maven,像下面这样的代码片段应该可以达到目的。注意,这只是插件定义,而不是完整的pom.xml:
关于这个插件的最新文档:参见https://maven.apache.org/plugins/maven-jar-plugin/
<build>
<plugins>
<plugin>
<!-- Build an executable JAR -->
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.1.0</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>com.mypackage.MyClass</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
(选择适合您项目的<版本>。)
对于Ant,下面的代码段应该有所帮助:
<jar destfile="build/main/checksites.jar">
<fileset dir="build/main/classes"/>
<zipfileset includes="**/*.class" src="lib/main/some.jar"/>
<manifest>
<attribute name="Main-Class" value="com.acme.checksites.Main"/>
</manifest>
</jar>
感谢迈克尔·尼曼德-
Gradle:
plugins {
id 'java'
}
jar {
manifest {
attributes(
'Main-Class': 'com.mypackage.MyClass'
)
}
}
任何可执行的jar文件都应该通过点击或使用命令提示符运行,如java -jar app.jar(使用“如果jar路径包含空格”-即java -jar“C:\文件夹名称\app.jar”)。如果您的可执行jar没有运行,这意味着它没有正确创建。
为了更好地理解,提取jar文件(或使用任何工具查看,对于windows 7-Zip是一个很好的工具),并检查/META-INF/MANIFEST.MF下的文件。如果你找到任何条目
Main-Class: your.package.name.ClaaswithMain -那么它就可以了,否则你必须提供它。
注意在MANIFEST上附加Main-Class条目。MF文件,检查你在哪里保存它!
对于maven,这就是解决它的方法(对我来说,对于GitHub上的vetle代码库):
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.0</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>org.lazydevs.veetle.api.VeetleAPI</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
欢呼声……
你可以简单地遵循这一步 创建一个jar文件
jar -cfm jarfile-name manifest-filename Class-file name
在运行jar文件时,像这样简单地运行
java -cp jarfile-name main-classname
这是因为Java无法在MANIFEST中找到Main属性。MF文件。 Main属性对于告诉java应该使用哪个类作为应用程序的入口点是必要的。在jar文件中,是MANIFEST。MF文件位于META-INF文件夹中。想知道如何查看jar文件中的内容吗?用WinRAR打开jar文件。
MANIFEST中的主属性。MF是这样的:
Main-Class: <packagename>.<classname>
当manifest中缺少这一行时,您会得到这个“no main manifest attribute”错误。MF文件。
在MANIFEST中指定这个属性真的很麻烦。MF文件。
更新:我刚刚找到了一种非常简洁的方法来在eclipse中指定应用程序的入口点。 当你说导出时,
Select Jar and next
[ give it a name in the next window ] and next
and next again
and you'll see " Select the class of the application entry point".
Just pick a class and Eclipse will automatically build a cool MANIFEST.MF for you.
或者,你也可以使用maven-assembly-plugin,如下面的例子所示:
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<mainClass>com.package.MainClass</mainClass>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</plugin>
在这个例子中,节中指定的所有依赖jar都将自动包含在您的单个jar中。注意,jar-with-dependencies应该按字面意思写为,而不是替换为您想要包含的jar文件名。
对我来说,没有一个答案真的有帮助-我在正确的地方有清单文件,包含主类和所有东西。让我跌倒的是:
警告:要从中创建清单的文本文件必须 以新行或回车结束。最后一行不会 如果不以新行或回车符结束,则正确解析。
(来源)。在清单的末尾添加换行符可以解决这个问题。
你可能和我有同样的问题。创建。jar文件后,编写jar xf app.jar META-INF/MANIFEST.MF。这将创建文件的副本到当前目录,以便读取它。如果它只是说:
Manifest-Version: 1.0 创建对象:Oracle Corporation (Oracle Corporation)
并且不包含“Main-Class”声明,那么我认为你找到了你的问题。
但我不知道如何解决这个问题。我在StackOverflow上查询了其他有相同/类似问题的人,但找不到答案。然而,有了这些信息,你可能会得到更好的帮助(考虑到你和我有同样的问题)。
编辑:我尝试了一个清单文件,但没有让它工作,但我的错误是在创建jar文件时只命名了一个类。我写了*.class,现在可以工作了。
虽然我不知道为什么需要创建一个清单文件。但我想只要管用就好。
对我来说,发生这个错误仅仅是因为我忘记告诉Eclipse我想要一个可运行的jar文件,而不是一个简单的库jar文件。因此,当您在Eclipse中创建jar文件时,请确保单击正确的单选按钮
我也遇到过同样的问题,现在已经解决了:) 只要遵循以下步骤,错误可能是任何东西,但下面的步骤使过程更顺畅。我花了很多时间来寻找解决办法。
1.尝试重新启动Eclipse(如果您正在使用Eclipse构建JAR文件) ——>实际上,这有助于我的问题,导出JAR文件正确。
2.eclipse重新启动后,尝试查看eclipse是否能够通过Java项目识别主类/方法——>右键单击——>运行为——>运行配置——> main——>单击搜索按钮,查看eclipse是否能够在JAR文件中查找主类。 这是为了验证JAR文件将拥有主类的入口点。
在此之后,将您的Java动态项目导出为“可运行的JAR”文件而不是JAR文件。 在Java启动配置中,选择您的主类。 导出jar文件后,使用下面的命令执行。 java -cp[你的JAR]. JAR[完整的包]。MainClass 例如:java -cp AppleTCRuleAudit.jar com.apple.tcruleaudit.classes.TCRuleAudit .jar 您可能会遇到不支持的java版本错误。修复方法是更改shell bash概要文件中的java_home,使之与用于在eclipse中编译项目的Java版本相匹配。
希望这能有所帮助!如果您还有什么问题,请告诉我。
Gradle的答案是添加一个jar/manifest/attributes设置,像这样:
apply plugin: 'java'
jar {
manifest {
attributes 'Main-Class': 'com.package.app.Class'
}
}
我在使用IntelliJ IDEA创建一个罐子时遇到了这个问题。请看这个讨论。
解决这个问题的方法是重新创建jar工件,选择jar > From依赖模块,但不接受META-INF/MANIFEST.MF的默认目录。将-/src/main/java改为-/src/main/resources。
否则,它会在jar中包含一个清单文件,而不是- src/main/java中应该包含的清单文件。
如果您正在使用命令行组装.jar,则可以在不添加清单文件的情况下指向主文件。例子:
jar cfve app.jar TheNameOfClassWithMainMethod *.class
(参数"e"是这样做的:TheNameOfClassWithMainMethod是一个类的名称,带有方法main()和app.jar -可执行文件的名称。jar和*.class -只是所有的类文件组装)
如果使用Maven,请在pom中包含以下内容
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.2.RELEASE</version>
</parent>
<properties>
<java.version>1.8</java.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
检查你的jar文件MANIFEST。MF Main-Class是否可用
first.java
class first
{
public static void main (String arg[ ])
{
System.out.println("Welcome to the world of Java");
}
}
之前:
Manifest-Version: 1.0
Created-By: 1.7.0_80 (Oracle Corporation)
sony@sony-VPCEH25EN:~/Documents$ java -jar first.jar
no main manifest attribute, in first.jar
后:
Manifest-Version: 1.0
Created-By: 1.7.0_80 (Oracle Corporation)
Main-Class: first
sony@sony-VPCEH25EN:~/Documents$ java -jar first.jar
Welcome to the world of Java
我和你有相似的问题, 在下面的语法中成功创建。war文件:-
Jar {cvf} [Jar -file] [manifest-file]
清单 当创建(c)或更新(u) JAR文件时,manifest操作数用要包含在manifest中的属性的名称和值定义先前存在的清单文件。MF在JAR文件中。如果f选项'[1]'存在,则必须指定清单操作数。
为了创建清单文件,你需要为某些属性定义一个值,你可以在(.WAR)文件名后面加上星号,以避免创建清单文件:-
罐子 -cvf foo.war *
老实说,我不知道这是否是一个最好的做法,但它为我工作:)。
我也有同样的问题。这里提到的许多解决方案并没有提供完整的内容,因此我将尝试向您概述如何从命令行打包jar文件。
如果您想在包中包含.class文件,请将包添加在.java. xml文件的开头。 Test.java 包testpackage; 公共类测验 { ... } 使用包名给出的结构来编译你的.class文件的代码: Javac -d。Test.java d。使编译器创建所需的目录结构。 在打包.jar文件时,您需要指示jar例程如何打包它。这里我们使用选项集cvfeP。这是为了保持包结构(选项P),指定入口点,以便清单文件包含有意义的信息(选项e)。选项f允许您指定文件名,选项c创建一个存档,选项v将输出设置为详细。这里需要注意的重要事项是P和e。 然后是我们想要的jar的名称test.jar。 然后是入口点。 然后是-C。<packagename>/从该文件夹中获取类文件,并保留文件夹结构。 jar cvfeP test.jar testpackage. jar测试-C。testpackage / 检查压缩程序中的.jar文件。它应该具有以下结构 test.jar meta - inf |清单。曼氏金融 testpackage | Test.class 清单。MF应该包含以下内容 Manifest-Version: 1.0 创建对象:JDK版本> (Oracle Corporation) 主类:testpackage。测试 如果你手动编辑你的清单,一定要保持换行符在最后,否则java不会识别它。 执行你的.jar文件 Java -jar test.jar
因为您已经添加了MANIFEST。MF,我认为你应该考虑这个文件中Field的顺序。我的env是java版本“1.8.0_91”
还有我的舱单。MF为这里
// MANIFEST.MF
Manifest-Version: 1.0
Created-By: 1.8.0_91 (Oracle Corporation)
Main-Class: HelloWorldSwing
// run
~ java -jar HelloWorldSwing.jar
no main manifest attribute, in HelloWorldSwing.jar
然而,这如下所述
Manifest-Version: 1.0
Main-Class: HelloWorldSwing
Created-By: 1.8.0_91 (Oracle Corporation)
//this run swing normally
以上答案对我来说只是部分帮助。java -cp是答案的一部分,但我需要关于如何识别要运行的类的更具体的信息。以下是对我有效的方法:
步骤1:找到我需要运行的类
jar tf /path/to/myjar.jar | more
结果最上面的几行是:
META-INF/
META-INF/MANIFEST.MF
somepath/
somepath/App.class
META-INF/maven/
...
App.class包含了要运行的主类。我不能百分之百确定你是否总是认为你需要的课程是第一个,但它是为我。如果不是,我想使用grep排除与库相关的结果以将类列表缩减到可管理的大小并不太难。
接下来就很简单了:我只需要使用该路径(减去“.class”后缀):
java -cp /path/to/myjar.jar somepath/App
(第一个帖子-所以可能不干净)
这是我对OS X 11.6的修复,基于maven的Netbeans 8.2程序。到目前为止,我的应用程序是100%的Netbeans -没有调整(只是一些shell逃脱为不可能!)。
在这里和其他地方尝试了几乎所有的答案都无济于事之后,我回到了“使用有用的东西”的艺术上。
上面的答案(olivier-refalo,谢谢)看起来是正确的起点,但并没有帮助。
看看其他成功的项目,我注意到清单行中有一些微小的差异:
addClasspath, classpathPrefix不存在(已删除) mainClass缺少了“com”。(使用NB ->项目 属性->运行->主类->浏览指定)
不知道为什么(我只有3个月的java)或如何,但只能说这是有效的。
下面是修改后的manifest块:
<manifest>
<mainClass>mypackage.MyClass</mainClass>
</manifest>
我刚才得到了同样的错误。 如果你正在使用gradle,只需在你的gradle.build中添加下一个:
apply plugin: 'java'
jar {
manifest {
attributes 'Main-Class': 'com.company.project.MainClass'
}
}
其中com.company.project.MainClass使用公共静态void main(String[] args)方法的类的路径。
我只想明确一点
Main-Class: <packagename>.<classname>
如果你没有包,你必须忽略这部分,就像这样:
Main-Class: <classname>
我个人认为这里所有的答案都是对问题的误解。这个问题的答案在于spring-boot构建.jar的方式不同。每个人都知道Spring Boot设置了一个这样的清单,这与每个人都认为这是一个标准的.jar启动不同,这可能是也可能不是:
Start-Class: com.myco.eventlogging.MyService
Spring-Boot-Classes: BOOT-INF/classes/
Spring-Boot-Lib: BOOT-INF/lib/
Spring-Boot-Version: 1.4.0.RELEASE
Created-By: Apache Maven 3.3.9
Build-Jdk: 1.8.0_131
Main-Class: org.springframework.boot.loader.JarLauncher
也许它需要在类路径上使用org.springframework.boot.loader.JarLauncher来执行?
我找到了一个新的解决方案,坏manifest生成!
用WinRAR这样的zip编辑器打开jar文件 点击META-INF 添加或编辑 添加: 创建一个名为MANIFEST的文本文件。MF在一个名为META-INF的文件夹中 并添加以下一行: Manifest-Version: 1.0 主类:package.ex.com.views.mainClassName 保存文件并将其添加到zip文件中 编辑: 拖出文件修改MANIFEST。MF添加前一行 打开cmd,输入:java -jar c:/path/JarName.jar
现在应该可以正常工作了!
我也有同样的问题。通过添加以下行到pom文件使其工作。该插件将确保应用程序的构建过程中所有必要的步骤。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
找到了一个很好的解决方案,在任何这种情况下都会有所帮助,因为你只需要一个可运行的罐子,这是你在大多数情况下所做的。 如果您的应用程序在Intellij Idea中运行,请遵循以下步骤: 1)进入模块设置和工件,并添加一个jar和定义主类 2)然后在菜单中选择Build,点击“Build artifact”,你就会得到这个罐子。
即使我更改了源文件夹并使用scala而不是java,这种方法仍然有效。
大多数的解决方案对我来说都不奏效,但我的教练帮助了我 我想在这里分享他的解决方案 我使用kali Linux终端,但应该在所有debian都很好
javac *.java
nano MANIFEST.MF
在文件类型中
主类:主要 或者不管你的主文件名是什么(如果存在包名,请确保添加包名)
jar -cvmf MANIFEST.MF new.jar *.class
现在运行文件use
java -jar new.jar
或者你可以去文件的属性中检查
允许文件作为程序执行 双击它
这对我有帮助,而上面的大多数答案都没有
MAVEN的问题在于它试图包括第一个MANIFEST。MF文件从第一个库从依赖而不是我们自己的清单。Mf当你使用神器的时候!
将jar.jar重命名为jar.zip 打开清单。MF文件从META-INF\MANIFEST。曼氏金融 复制真实的清单。MAVEN已经在你的项目中生成了MF 其中包括: Manifest-Version: 1.0 主类:yourpacket。你的主类(例如info.data.MainClass) 替换MANIFEST的内容。你罐子里的MF。 将jar.zip重命名为jar.jar。 现在java -jar yourjar.jar工作得很完美。
OR!
简单地创建您自己的MANIFEST。MF和:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<archive>
<manifestFile> Your path like: src/main/resources/META-INF/MANIFEST.MF </manifestFile>
<index>true</index>
<manifest>
<addClasspath>true</addClasspath>
</manifest>
</archive>
</configuration>
</plugin>
但是如果您使用maven面板(或maven命令行),您可以强制它生成自己的清单并将其包含到JAR文件中。
将以下代码添加到you pom.xml的构建部分: <插件> <插件> < groupId > org.apache.maven.plugins < / groupId > < artifactId > maven-assembly-plugin < / artifactId > <版本> 3.2.0 > < /版本 执行< > 执行< > <阶段>包> < /阶段 <目标> <目标>单> < /目标 > < /目标 执行< / > > < /执行 < >配置 < descriptorRefs > < descriptorRef > jar-with-dependencies < / descriptorRef > < / descriptorRefs > <文件> 真正<指数> < /指数> <清单> 真正< addClasspath > < / addClasspath > < mainClass > yourpacket。yourmainclass(例如info.data.MainClass)</mainClass> . /mainClass < /清单> < manifestEntries > < >发展模式> < /模式 < url > $ {project.url} < / url > < / manifestEntries > < / >存档 < /配置> < /插件> 打开MAVEN面板(在Intellij中)并执行“Install”。它将生成MANIFEST文件,并将包含所有依赖项的JAR文件属性编译到“Target”文件夹中。它还将被安装到本地maven存储库中。
我在执行mvn包时得到相同的错误。这就是我解决问题的方法。
我用的是maven-multi模块。我正面临这个问题,因为我错误地在parent pom中添加了下面的部分。
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
然后在子模块中添加这个pom.xml并从父pom中删除后解决了我的问题。
我试过了,对我很有效。 MVN清洁安装包应该工作。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
创建文件夹META-INF和文件MANIFEST。MF在该文件夹中,内容如下:
Manifest-Version: 1.0
Class-Path: .
Main-Class: [YOUR_MAIN_CLASS]
然后编译,包括该清单文件。
只需将其添加到java模块的build.gradle中。它将创建可执行jar。 它将包含存档中的依赖库。
jar {
manifest {
attributes "Main-Class": "com.company.application.Main"
}
from {
configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
}
}
这将导致[module_name]/build/libs/[module_name].jar文件。 我用shell进行了测试。
在我的案例中,问题是<build>下的<pluginManagement>使事情不能正常工作。
我原来的pom.xml:
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
...
...
...
</pluginManagement>
</build>
删除<pluginManagement>后,错误就消失了。
如果你的on maven和pom。xml是这样的
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<!-- dependencies -->
</dependencies>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
只需注释pluginManagement,就会得到下面的pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<!-- dependencies -->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
以我为例——我从事的是一个多模块项目——我可以用以下方式介绍这个问题:
我将其添加到父文件pom.xml中,这导致了问题。即,值为true的skip:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<!--
besides hindering the packaging, this also skips running the app after build when calling spring-boot:run. You have to enable it in the
corresponding module by setting skip to false, there.
-->
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
我修复了这个问题,通过添加相同的配置到模块,我想打包成一个jar,但改变了跳过的值为false:
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<configuration>
<mainClass>${project.mainClass}</mainClass>
<layout>ZIP</layout>
<skip>false</skip>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
<execution>
<id>build-info</id>
<goals>
<goal>build-info</goal>
</goals>
</execution>
</executions>
</plugin>
您可以简单地将其添加到属性标签中。当您有多个子模块时,也可以这样做,为每个子模块的pom.xml添加它
这是我的pom。xml,
<properties>
<java.version>11</java.version>
<startclass>com.sample.MyApplication</start-class>
</properties>