我们正在从jdk 8迁移到openjdk11。我们的一些使用soap调用第三方api的项目均因错误而失败:
java.lang.NoClassDefFoundError: javax/xml/ws/handler/soap/SOAPHandler
做完一些研究后,我尝试添加依赖项:
[ 引用:
]
<dependency>
<groupId>javax.annotation</groupId>
<artifactId>javax.annotation-api</artifactId>
</dependency>
<dependency>
<groupId>xml-apis</groupId>
<artifactId>xml-apis</artifactId>
</dependency>
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-core</artifactId>
<version>2.3.0.1</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>javax.xml.soap</groupId>
<artifactId>javax.xml.soap-api</artifactId>
<version>1.3.5</version>
</dependency>
没有工作。我可以对替代方案有所了解吗?
答案 0 :(得分:9)
javax
API已转换为Jakarta
,因此在2020年,适当的依赖关系如下:
<dependency>
<groupId>jakarta.xml.ws</groupId>
<artifactId>jakarta.xml.ws-api</artifactId>
<version>2.3.3</version>
</dependency>
这是一篇概述发生了什么的文章: Java Magazine - Transition from Java EE to Jakarta EE
这是旧工件与新工件之间的very useful table with mappings。
答案 1 :(得分:2)
在您的依赖项中包含jaxws-api
:
<dependency>
<groupId>javax.xml.ws</groupId>
<artifactId>jaxws-api</artifactId>
<version>2.3.1</version>
</dependency>
答案 2 :(得分:0)
由于这是 google 上的第一个结果,我的问题是由于在 Tomcat 公共文件夹 javax.xml.ws
上有一个需要 /usr/local/tomcat/lib
类的 jar。
Tomcat classloader hierarchy 是
Bootstrap
|
System
|
Common
/ \
Webapp1 Webapp2 ...
在 Java 8 上,公共类加载器可以加载这些类,因为它们位于 Java JRE 本身上,但在 Java 11 上,javax.xml.ws
类位于 Webapp1 上,而 Tomcat 公共类加载器无法加载这些。
对我来说,解决方案是不再将 jar 部署到 Tomcat 公共库文件夹中。