sti*_*ksu 99 java jar class file classloader
我有一个JAR文件,我需要获取此JAR文件中所有类的名称.我怎样才能做到这一点?
我搜索了它,看到了一些关于JarFile或Java的东西,ClassLoader但我不知道该怎么做.
小智 169
您可以使用Java jar工具.在txt文件中列出jar文件的内容,您可以看到jar中的所有类.
jar tvf jarfile.jar
Run Code Online (Sandbox Code Playgroud)
sig*_*ned 63
不幸的是,Java没有提供一种简单的方法来列出"本机"JRE中的类.这留下了几个选项:(a)对于任何给定的JAR文件,您可以列出该JAR文件中的条目,查找.class文件,然后确定每个.class文件代表哪个Java类; 或者(b)您可以使用为您执行此操作的库.
在这个选项中,我们将填充classNamesjar文件中包含的所有Java类的列表/path/to/jar/file.jar.
List<String> classNames = new ArrayList<String>();
ZipInputStream zip = new ZipInputStream(new FileInputStream("/path/to/jar/file.jar"));
for (ZipEntry entry = zip.getNextEntry(); entry != null; entry = zip.getNextEntry()) {
if (!entry.isDirectory() && entry.getName().endsWith(".class")) {
// This ZipEntry represents a class. Now, what class does it represent?
String className = entry.getName().replace('/', '.'); // including ".class"
classNames.add(className.substring(0, className.length() - ".class".length()));
}
}
Run Code Online (Sandbox Code Playgroud)
番石榴已经有ClassPath至少14.0,我已经使用和喜欢.一个好处ClassPath是它不会加载它找到的类,这对于扫描大量类很重要.
ClassPath cp=ClassPath.from(Thread.currentThread().getContextClassLoader());
for(ClassPath.ClassInfo info : cp.getTopLevelClassesRecurusive("my.package.name")) {
// Do stuff with classes here...
}
Run Code Online (Sandbox Code Playgroud)
我没有亲自使用过Reflections库,但它似乎很受欢迎.网站上提供了一些很好的例子,就像在这个快速方法中加载任何 JAR文件提供的包中的所有类一样,这对您的应用程序也很有用.
Reflections reflections = new Reflections("my.project.prefix");
Set<Class<? extends SomeType>> subTypes = reflections.getSubTypesOf(SomeType.class);
Set<Class<?>> annotated = reflections.getTypesAnnotatedWith(SomeAnnotation.class);
Run Code Online (Sandbox Code Playgroud)
pra*_*upd 19
也许你正在寻找jar命令来获取终端中的类列表,
$ jar tf ~/.m2/repository/org/apache/spark/spark-assembly/1.2.0-SNAPSHOT/spark-assembly-1.2.0-SNAPSHOT-hadoop1.0.4.jar
META-INF/
META-INF/MANIFEST.MF
org/
org/apache/
org/apache/spark/
org/apache/spark/unused/
org/apache/spark/unused/UnusedStubClass.class
META-INF/maven/
META-INF/maven/org.spark-project.spark/
META-INF/maven/org.spark-project.spark/unused/
META-INF/maven/org.spark-project.spark/unused/pom.xml
META-INF/maven/org.spark-project.spark/unused/pom.properties
META-INF/NOTICE
Run Code Online (Sandbox Code Playgroud)
哪里,
-t list table of contents for archive
-f specify archive file name
Run Code Online (Sandbox Code Playgroud)
或者,只是grep上面的结果.class只看到es
$ jar tf ~/.m2/repository/org/apache/spark/spark-assembly/1.2.0-SNAPSHOT/spark-assembly-1.2.0-SNAPSHOT-hadoop1.0.4.jar | grep .class
org/apache/spark/unused/UnusedStubClass.class
Run Code Online (Sandbox Code Playgroud)
要查看classes的数量,
jar tvf launcher/target/usergrid-launcher-1.0-SNAPSHOT.jar | grep .class | wc -l
61079
Run Code Online (Sandbox Code Playgroud)
这是我正在使用的黑客:
您可以java像这样使用自动完成:
java -cp path_to.jar <Tab>
Run Code Online (Sandbox Code Playgroud)
这将为您提供可作为起始类传递的类列表.当然,尝试使用没有主文件的文件也不会做任何事情,但是你可以看到java内部的类.jar被调用的内容.
小智 5
你可以试试:
jar tvf jarfile.jar
Run Code Online (Sandbox Code Playgroud)
仅当您的jar可执行时,这才是有用的,即在清单中您已将某个类定义为主类