问题
我有一个JAR文件,我需要获取此JAR文件中所有类的名称。我怎样才能做到这一点?
我搜索了它,看到了有关JarFile或JavaClassLoader的内容,但我不知道该怎么做。
#1 热门回答(140 赞)
你可以使用Javajartool。在txt文件中列出jar文件的内容,你可以看到jar中的所有类。
jar tvf jarfile.jar
#2 热门回答(59 赞)
不幸的是,Java没有提供一种简单的方法来列出"本机"JRE中的类。这给你留下了几个选项:(a)对于任何给定的JAR文件,你可以列出该JAR文件中的条目,找到.class文件,然后确定each.classfile代表哪个Java类;或者(b)你可以使用为你执行此操作的库。
##选项(a):手动扫描JAR文件
在此选项中,我们将使用jar文件at/path/to/jar/file.jar中包含的所有Java类的列表填充classNames。
List classNames = new ArrayList();
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()));
}
}
##选项(b):使用专门的反射库
###番石榴
Guava已经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...
}
###思考
我没有亲自使用过the Reflections library,但它似乎很受欢迎。网站上提供了一些很好的例子,比如这种快速的方法来加载由anyJAR文件提供的包中的所有类,这对你的应用程序也很有用。
Reflections reflections = new Reflections("my.project.prefix");
Set> subTypes = reflections.getSubTypesOf(SomeType.class);
Set> annotated = reflections.getTypesAnnotatedWith(SomeAnnotation.class);
#3 热门回答(18 赞)
也许你正在寻找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
哪里,
-t list table of contents for archive
-f specify archive file name
或者,只是grep上面的结果只能看到.classes
$ 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
要查看的数量是class,
jar tvf launcher/target/usergrid-launcher-1.0-SNAPSHOT.jar | grep .class | wc -l
61079