摘要:一般來說,可以被加入到中的東西,除了文件夾,就只有包了但有的時候,我們可能希望將一個已經存在的包里面的所有文件加入,這包括下的所有文件和下的所有包直接將該包加入中是不能達到上述目的的,那么就可以使用下面這個工具達到此目的用法
一般來說,可以被加入到java classpath中的東西,除了文件夾,就只有jar包了;
但有的時候,我們可能希望將一個已經存在的war包里面的所有class文件加入classpath,這包括/WEB-INF/classes下的所有class文件和/WEB-INF/lib下的所有jar包;
直接將該war包加入classpath中是不能達到上述目的的,那么就可以使用下面這個工具達到此目的:
package kilim.tools; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.MalformedURLException; import java.net.URL; import java.net.URLClassLoader; import java.util.Enumeration; import java.util.jar.JarEntry; import java.util.jar.JarFile; /** * classloader which allows user to set a war archive path to be included in the * classpath dynamically. * * @author pf_miles * */ public class WarPathClassLoader extends URLClassLoader { private boolean warPathSet; private String explodedWarPath; public WarPathClassLoader(ClassLoader parent) { super(new URL[0], parent); } public void setWarPath(String path) { if (this.warPathSet) throw new RuntimeException("War archive path already set. Kilim-fiber tools cannot weave multiple war archives at the same time."); File w = new File(path); if (w.exists()) { final File dir; try { warPathSet = true; // 0.create a temp dir dir = createTempDirectory(w.getName()); // 1.extract the war to the temp dir extractTo(w, dir); // 2.add /WEB-INF/classes to cp File clses = locateFile(dir, "WEB-INF", "classes"); super.addURL(clses.toURI().toURL()); // 3.add all jars under /WEB-INF/lib/ to cp File lib = locateFile(dir, "WEB-INF", "lib"); File[] jars = lib.listFiles(); for (File j : jars) super.addURL(j.toURI().toURL()); } catch (MalformedURLException e) { throw new RuntimeException(e); } // delete temp dir when exit Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() { public void run() { if (dir != null) { delRecur(dir); } } })); this.explodedWarPath = dir.getAbsolutePath(); } else { throw new RuntimeException("File not exists: " + path); } } private static void delRecur(File file) { if (!file.exists()) return; if (file.isDirectory()) { // 1.del sub files first for (File s : file.listFiles()) delRecur(s); // 2.del the dir file.delete(); } else { file.delete(); } } private static File locateFile(File dir, String... paths) { File cur = dir; outter: for (String p : paths) { File[] all = cur.listFiles(); for (File f : all) { if (p.equals(f.getName())) { cur = f; continue outter; } } throw new RuntimeException("No path named "" + p + "" found in file: " + cur.getAbsolutePath()); } return cur; } // extract content of "w" to dir private static void extractTo(File w, File dir) { String dirPath = dir.getAbsolutePath(); if (!dirPath.endsWith("/")) dirPath += "/"; try { JarFile jar = new JarFile(w); Enumeratione = jar.entries(); byte[] buf = new byte[4096]; while (e.hasMoreElements()) { JarEntry file = (JarEntry) e.nextElement(); File f = new File(dirPath + file.getName()); if (file.isDirectory()) { // if its a directory, create it f.mkdirs(); continue; } InputStream is = jar.getInputStream(file); FileOutputStream fos = ensureOpen(f); // write contents of "is" to "fos" for (int avai = is.read(buf); avai != -1; avai = is.read(buf)) { fos.write(buf, 0, avai); } fos.close(); is.close(); } } catch (IOException e) { throw new RuntimeException(e); } } // if does not exist, create one, and ensure all parent dirs exist private static FileOutputStream ensureOpen(File f) throws IOException { if (!f.exists()) { File p = f.getParentFile(); if (p != null && !p.exists()) p.mkdirs(); f.createNewFile(); } return new FileOutputStream(f); } private static File createTempDirectory(String dirName) { final File temp; try { temp = File.createTempFile(dirName, Long.toString(System.currentTimeMillis())); temp.deleteOnExit(); } catch (IOException e) { throw new RuntimeException(e); } if (!(temp.delete())) { throw new RuntimeException("Could not delete temp file: " + temp.getAbsolutePath()); } if (!(temp.mkdir())) { throw new RuntimeException("Could not create temp directory: " + temp.getAbsolutePath()); } return (temp); } /** * get the temporary directory path which contains the exploded war files */ public String getExplodedWarPath() { if (this.explodedWarPath == null) throw new RuntimeException(""explodedWarPath" is null, maybe the war path is not set."); return this.explodedWarPath; } }
用法:new一個WarPathClassLoader實例,然后調用setWarPath指定war包所在位置即可
gist地址:https://gist.github.com/pfmiles/2002fdace1caa247618b
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/64418.html
摘要:的打包結構改動是這個引入的這個的本意是簡化的繼承關系,以一種直觀的優先的方式來實現,同時打包結構和傳統的包應用更接近。目前的繼承關系帶來的一些影響有很多用戶可能會發現,一些代碼在里跑得很好,但是在實際部署運行時不工作。 前言 對spring boot本身啟動原理的分析,請參考:http://hengyunabc.github.io/s... Spring boot里的ClassLoad...
時間:2017年12月01日星期五說明:本文部分內容均來自慕課網。@慕課網:http://www.imooc.com 教學源碼:無 學習源碼:https://github.com/zccodere/s... 第一章:課程介紹 1-1 課程介紹 熱部署的使用場景 本地調式 線上發布 熱部署的使用優點 無論本地還是線上,都適用 無需重啟服務器:提高開發、調式效率、提升發布、運維效率、降低運維成本 前置...
摘要:注本系列文章所用版本為介紹是個輕量級的框架,致力于讓程序員實現快速高效開發,它具有以下幾個方面的優勢熱加載。在調試模式下,所有修改會及時生效。拋棄配置文件。約定大于配置。 注:本系列文章所用play版本為1.2.6 介紹 Play framework是個輕量級的RESTful框架,致力于讓java程序員實現快速高效開發,它具有以下幾個方面的優勢: 熱加載。在調試模式下,所有修改會及時...
摘要:第一次寫技術文章,主要內容是使用創建一個簡單的項目,如有操作或理解錯誤請務必指出,當謙虛學習?;舅枷肫鋵嵕褪且粋€項目引用別的模塊包,最終項目被打成包發布。 第一次寫技術文章,主要內容是使用maven創建一個簡單的SpringMVC WEB 項目,如有操作或理解錯誤請務必指出,當謙虛學習。做這一次的工作主要是因為想加強一下自己對Spring Web 項目的理解,因為平時都是直接寫業務代...
摘要:比如說,就是復姓,名字為的類別則是復姓,名字為的類別。先介紹的機制基本原則需要將類文件切實安置到其所歸屬之所對應的相對路徑下。把源代碼文件,文件和其他文件有條理的進行一個組織,以供來使用。可以使用通配符,代表某下所有的,不包括子目錄。 一些人用了一陣子的Java,可是對于 Java 的 package 跟 import 還是不太了解。很多人以為原始碼 .java 文件中的 import...
閱讀 1382·2021-11-22 09:34
閱讀 2587·2021-11-12 10:36
閱讀 1119·2021-11-11 16:55
閱讀 2332·2020-06-22 14:43
閱讀 1474·2019-08-30 15:55
閱讀 1986·2019-08-30 15:53
閱讀 1773·2019-08-30 10:50
閱讀 1230·2019-08-29 12:15