Merge pull request #12397 from eugenp/BAEL-5632
BAEL-5632 add jar example
This commit is contained in:
commit
e827d93f03
|
@ -0,0 +1,19 @@
|
|||
package com.baeldung.createjar;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.jar.*;
|
||||
import com.baeldung.createjar.JarTool;
|
||||
|
||||
public class Driver {
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
JarTool tool = new JarTool();
|
||||
tool.startManifest();
|
||||
tool.addToManifest("Main-Class", "com.baeldung.createjar.HelloWorld");
|
||||
JarOutputStream target = tool.openJar("HelloWorld.jar");
|
||||
|
||||
tool.addFile(target, System.getProperty("user.dir") + "\\src\\main\\java", System.getProperty("user.dir") + "\\src\\main\\java\\com\\baeldung\\createjar\\HelloWorld.class");
|
||||
target.close();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
package com.baeldung.createjar;
|
||||
|
||||
public class HelloWorld {
|
||||
public static void main(String[] args) {
|
||||
System.out.println("Hello World!");
|
||||
}
|
||||
}
|
|
@ -0,0 +1,69 @@
|
|||
package com.baeldung.createjar;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.jar.*;
|
||||
|
||||
public class JarTool {
|
||||
private Manifest manifest = new Manifest();
|
||||
|
||||
public void addToManifest(String key, String value) {
|
||||
manifest.getMainAttributes()
|
||||
.put(new Attributes.Name(key), value);
|
||||
}
|
||||
|
||||
public void addDirectoryEntry(JarOutputStream target, String parentPath, File dir) throws IOException {
|
||||
String remaining = "";
|
||||
if (parentPath.endsWith(File.separator))
|
||||
remaining = dir.getAbsolutePath()
|
||||
.substring(parentPath.length());
|
||||
else
|
||||
remaining = dir.getAbsolutePath()
|
||||
.substring(parentPath.length() + 1);
|
||||
String name = remaining.replace("\\", "/");
|
||||
if (!name.endsWith("/"))
|
||||
name += "/";
|
||||
JarEntry entry = new JarEntry(name);
|
||||
entry.setTime(dir.lastModified());
|
||||
target.putNextEntry(entry);
|
||||
target.closeEntry();
|
||||
}
|
||||
|
||||
public void addFile(JarOutputStream target, String rootPath, String source) throws IOException {
|
||||
BufferedInputStream in = null;
|
||||
String remaining = "";
|
||||
if (rootPath.endsWith(File.separator))
|
||||
remaining = source.substring(rootPath.length());
|
||||
else
|
||||
remaining = source.substring(rootPath.length() + 1);
|
||||
String name = remaining.replace("\\", "/");
|
||||
JarEntry entry = new JarEntry(name);
|
||||
entry.setTime(new File(source).lastModified());
|
||||
target.putNextEntry(entry);
|
||||
in = new BufferedInputStream(new FileInputStream(source));
|
||||
byte[] buffer = new byte[1024];
|
||||
while (true) {
|
||||
int count = in.read(buffer);
|
||||
if (count == -1)
|
||||
break;
|
||||
target.write(buffer, 0, count);
|
||||
}
|
||||
target.closeEntry();
|
||||
in.close();
|
||||
}
|
||||
|
||||
public JarOutputStream openJar(String jarFile) throws IOException {
|
||||
JarOutputStream target = new JarOutputStream(new FileOutputStream(jarFile), manifest);
|
||||
return target;
|
||||
}
|
||||
|
||||
public void setMainClass(String mainFQCN) {
|
||||
if (mainFQCN != null && !mainFQCN.equals(""))
|
||||
manifest.getMainAttributes()
|
||||
.put(Attributes.Name.MAIN_CLASS, mainFQCN);
|
||||
}
|
||||
|
||||
public void startManifest() {
|
||||
manifest.getMainAttributes()
|
||||
.put(Attributes.Name.MANIFEST_VERSION, "1.0");
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue