我要做的是制作一个jar文件并运行它。我有一个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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>test</groupId>
<artifactId>test</artifactId>
<version>1.0-SNAPSHOT</version>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass>hola.test</mainClass>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.apache.spark</groupId>
<artifactId>spark-hive_2.11</artifactId>
<version>2.1.1</version>
</dependency>
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20160810</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.3</version>
</dependency>
<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>transport</artifactId>
<version>5.5.0</version>
</dependency>
</dependencies>
</project>
和我的清单
Manifest-Version: 1.0
Main-Class: hola.test
我的jar文件位于projectroot/out/artifacts/test_jar/test.jar
下,而我的清单位于projectroot/main/resources/meta-inf/manifest.mf
正如我所说的一些问题,如this one。我自己创建了文件夹,然后构建了我的工件,但没有帮助。我不记得在使用Netbeans时面对这个问题。这是Intelij的错误吗?还是我错过了一些观点? 这是错误输出
/usr/lib/jvm/java-1.8.0-openjdk-i386/bin/java -Dfile.encoding=UTF-8 -jar /home/saurab/sparkProjects/test/out/artifacts/test_jar/test.jar
Error: Could not find or load main class hola.test
我创建jar文件的步骤 1)进入项目结构 2)工件&gt;点击[+]&gt; jar&gt;来自具有依赖关系的模块&gt;选择主要类[在我的情况下是测试]&amp;将清单文件夹从main / java更改为main / resources&gt;点击[确定]&gt;点击[确定]