java怎么获取内容中的公司名_如何在jar文件中获取类的名称?

问题

我有一个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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值