我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
当前回答
我只想明确一点
Main-Class: <packagename>.<classname>
如果你没有包,你必须忽略这部分,就像这样:
Main-Class: <classname>
其他回答
我也有同样的问题。这里提到的许多解决方案并没有提供完整的内容,因此我将尝试向您概述如何从命令行打包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
您可能没有正确地创建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
或者,你也可以使用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文件名。
我个人认为这里所有的答案都是对问题的误解。这个问题的答案在于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来执行?