背景:之前jdk8环境下,使用的cxf框架,而且是动态加载解析作为客户端。大家一直相处的很愉快。但是最近升级jdk17,发现cxf不好用了。网上百度,大部分都是说升级cxf版本,并且添加jaxb的相关依赖就可以了。但是。。。我不还是解决不了啊。
本着快的解决不了,就仔细研究下看看想法,了解了下cxf动态解析的工作方式,发现了不对劲。
CXF动态调用WebService,一般包含以下步骤:
- 下载WSDL文件
- 将WSDL文件解析成Java代码模型
- 生成Java源码
- 编译源码->Class文件
- 创建ClassLoader
- 加载Class
- 创建数据绑定&类型初始化
- 使用这些Class完成WebService交互
- 废弃这些Class,等待JVM空闲时GC回收
原来如此,需要生成源码,需要加载class,问了提供WS的服务端,反馈说是jdk8提供的wsdl。莫非问题就在这个地方。
如果是这样解决的思路就有两个了。一个是从源头解决问题,让服务端升级jdk,估计不现实。哈哈,搞不定。另一个思路就是不要使用动态解析了,静态的安排上。cxf,axis2,xfire等几个流行框架都可以通过wsdl来生成相应的java桩代码,然后大家又可以愉快的玩耍了。
按照思路2来折腾,搞定收工,相关代码后续补充。