我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
我已经安装了一个应用程序,当我试图运行它(它是一个可执行的jar)什么都没有发生。当我从命令行运行它时:
Java -jar "app.jar"
我得到了以下信息:
在“app.jar”中没有主清单属性
通常,如果我自己创建了这个程序,我就会向清单文件添加一个主类属性。但在这种情况下,由于文件来自应用程序,我不能这样做。我还尝试提取jar,看看是否能找到主类,但有很多类,没有一个在它的名称中有“main”这个词。必须有一种方法来修复这个问题,因为程序在其他系统上运行良好。
当前回答
如果您正在使用命令行组装.jar,则可以在不添加清单文件的情况下指向主文件。例子:
jar cfve app.jar TheNameOfClassWithMainMethod *.class
(参数"e"是这样做的:TheNameOfClassWithMainMethod是一个类的名称,带有方法main()和app.jar -可执行文件的名称。jar和*.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进行了测试。
首先,这有点奇怪,看到你运行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'
)
}
}
如果你的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>
这应该是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是包含运行程序的主方法的类。(这个类是什么取决于程序,不可能从您提供的信息中判断出来)。
我和你有相似的问题, 在下面的语法中成功创建。war文件:-
Jar {cvf} [Jar -file] [manifest-file]
清单 当创建(c)或更新(u) JAR文件时,manifest操作数用要包含在manifest中的属性的名称和值定义先前存在的清单文件。MF在JAR文件中。如果f选项'[1]'存在,则必须指定清单操作数。
为了创建清单文件,你需要为某些属性定义一个值,你可以在(.WAR)文件名后面加上星号,以避免创建清单文件:-
罐子 -cvf foo.war *
老实说,我不知道这是否是一个最好的做法,但它为我工作:)。