我有一个命令行Java应用程序,该应用程序具有对其他libs / jars的依赖性。因此,我正在使用UPDATE
运行应用程序,例如-cp
。
我要做的是在我的Java应用程序中复制依赖库/ jar,并正确描述MANIFEST.MF,原因是我不再需要选项java -cp libs/* <package.MainClass> <args>
。
我的项目是一个maven项目,因此我正在使用-cp libs/*
复制JAR中的库并描述MANIFEST.MF。我现在的意思是:
maven-assembly-plugin
我的MANIFEST.MF看起来像这样的atm:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<version>3.1.1</version>
<configuration>
<archive>
<manifest>
<mainClass>MainClass</mainClass>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<id>dist</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
我的问题是:如何描述MANIFEST.MF文件,以便使用Manifest-Version: 1.0
Built-By: user
Class-Path: lib/deps_A.jar lib/deps_B.jar
Created-By: Apache Maven 3.6.0
Build-Jdk: 1.8.0_202
Main-Class: MainClass
运行我的应用程序?
答案 0 :(得分:0)
清单条目未在 SystemClassLoader 的URL中列出。
您必须手动从清单文件中获取它们。
ClassLoader cl = ClassLoader.getSystemClassLoader();
if (cl instanceof URLClassLoader) {
URLClassLoader ucl = (URLClassLoader) cl;
URL[] urLs = ucl.getURLs();
for (URL url : urLs) {
File file = new File(URLDecoder.decode(url.getFile()));
try (JarFile jarFile = new JarFile(file)){
Manifest manifest = jarFile.getManifest();
String attrs = manifest.getMainAttributes().getValue(Attributes.Name.CLASS_PATH.toString());
if(attrs!=null) {
String[] splits = attrs.split(" ");
for (String split: splits) {
// This is the name of the jar referenced in manifest.
System.out.println(split);
}
}
System.out.println(file);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}