mysql查找jdbc驱动包_查找已安装的JDBC驱动程序

小编典典

到目前为止,您需要扫描整个类路径(和子文件夹)以查找实现类的类java.sql.Driver。这样,您还将涵盖 没有

由手动Class#forName()或自动加载的驱动程序META-INF/services。

这是一个基本示例:

public static void main(String[] args) throws Exception {

List> drivers = findClassesImplementing(Driver.class);

System.out.println(drivers);

}

public static List> findClassesImplementing(Class cls) throws IOException {

List> classes = new ArrayList>();

for (URL root : Collections.list(Thread.currentThread().getContextClassLoader().getResources(""))) {

for (File file : findFiles(new File(root.getFile()), ".+\\.jar$")) {

JarFile jarFile = new JarFile(file);

for (JarEntry jarEntry : Collections.list(jarFile.entries())) {

String name = jarEntry.getName();

if (name.endsWith(".class")) try {

Class> found = Class.forName(name.replace("/", ".").replaceAll("\\.class$", ""));

if (cls.isAssignableFrom(found)) {

classes.add((Class) found);

}

} catch (Throwable ignore) {

// No real class file, or JAR not in classpath, or missing links.

}

}

}

}

return classes;

}

public static List findFiles(File directory, final String pattern) throws IOException {

File[] files = directory.listFiles(new FileFilter() {

public boolean accept(File file) {

return file.isDirectory() || file.getName().matches(pattern);

}

});

List found = new ArrayList(files.length);

for (File file : files) {

if (file.isDirectory()) {

found.addAll(findFiles(file, pattern));

} else {

found.add(file);

}

}

return found;

}

Set> drivers = reflections.getSubTypesOf(Driver.class);

2020-11-16

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值