SpringBoot自定义类加载器,项目打包成jar包后,加载不到Class

项目涉及需要留接口给第三方进行功能扩展,第三方实现统一的扩展接口后将扩展代码上传到了数据库,再执行扩展方法的时候再将扩展类加载到jvm内存。因为是加载项目外的class类,所以通过实现自定义类加载器继承了ClassLoader通过defineClass方法去实现外部类的加载。但是在通过spring-boot-maven-plugin插件打包后jar包内目录结构变化,项目中存在的类(如项目中统一的扩展类接口,依赖类等)都无法通过自定义类加载器加载到。

通过spring-boot-maven-plugin插件打包后jar包内目录结构

通过maven-jar-plugin插件打包后jar包内目录结构

解决方法 :不改变打包方式,通过继承线程上下文类加载器的方式,可以解决该问题

相关推荐
SXJR4 小时前
Spring前置准备(八)——ConfigurableApplicationContext和DefaultListableBeanFactory的区别
java·后端·spring
G探险者4 小时前
深入理解 KeepAlive:从 TCP 到连接池再到线程池的多层语义解析
后端
Takklin4 小时前
Java 面试笔记:深入理解接口
后端·面试
右子4 小时前
理解响应式设计—理念、实践与常见误解
前端·后端·响应式设计
濑户川4 小时前
深入理解Django 视图与 URL 路由:从基础到实战
后端·python·django
武子康4 小时前
大数据-120 - Flink滑动窗口(Sliding Window)详解:原理、应用场景与实现示例 基于时间驱动&基于事件驱动
大数据·后端·flink
IccBoY4 小时前
Java采用easyexcel组件进行excel表格单元格的自动合并
java·开发语言·excel
用户281113022214 小时前
分布式事务总结
后端
Hello.Reader4 小时前
Flink 广播状态(Broadcast State)实战从原理到落地
java·大数据·flink
xuejianxinokok4 小时前
新版本 python 3.14 性能到底如何?
后端·python