最近对接东软的一个项目中,有需要请求webservice数据的地方用invoke方法,起初在开发环境中测试的时候,没有出现任何问题,但是将包部署到服务器的时候,出现client调用invoke方法的时候,出现了一段异常:
Caused by: java.lang.ClassNotFoundException: com/sun/tools/internal/xjc/api/XJCat java.lang.Class.forName0(Native Method)at java.lang.Class.forName(Class.java:348)at org.apache.cxf.common.jaxb.JAXBUtils.createSchemaCompiler(JAXBUtils.java:706)... 44 more
在网上查了一些资料,很多人说就是缺少一个依赖,说这个依赖在jdk的tools.jar里里面,直接把这个包放项目lib下手动引进去就好,用反编译工具查看了一下这个jar包的结构,这个类确实在这里面,于是我把这个包引入这个项目lib里面,运行还是报同样的错,说明这个方法不行,这样引入,项目无法依赖到。
进一步分析,同样的代码,在idea中运行正常,在linux服务器里面出现这样的异常,说明不是项目本身的问题,一定是java环境的问题。想了一下,自己所用的服务器的jdk是centOS系统在安装的时候自带的,可能会和自己手动安装的有些差异,应该从这个地方入手。
因为公司用的docker部署,再重新安装jdk并指引到tools.jar,看了下网上教程都很麻烦,于是在StackOverflow上搜了下,引入下面三个包就可覆盖引用jdk的tools:
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.2.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.xml/jaxb-impl -->
<dependency>
<groupId>javax.xml</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.sun.xml.bind/jaxb-xjc -->
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-xjc</artifactId>
<version>2.2.1.1</version>
</dependency>
问题解决,mark一下方便日后再碰到时能快速处理。