我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:

Java -jar "app.jar"

我得到了以下信息:

在“app.jar”中没有主清单属性

通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。


如果jar不遵守规则,它就不是一个可执行的jar。


这应该是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:

java -cp yourJarName.jar your.package..your.MainClass

您可能没有正确地创建jar文件:

例如:在创建jar时缺少选项m

以下工作:

jar -cvfm MyJar.jar Manifest.txt *.class

你可以简单地遵循这一步 创建一个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'
    }
}

在您的本地.m2目录中检查该工件的子目录。 如果存在-删除它,并再次执行Maven更新


我在使用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


我遇到了这个问题,我最近在Netbeans 8中解决了这个问题(参考下图):

转到项目的属性。 点击Run。 使用浏览指定项目的主类。 构建并运行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

我今天也遇到了同样的问题。我的问题解决了,我移动META-INF到资源文件夹。


(第一个帖子-所以可能不干净)

这是我对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>