根据 https://wiki.eclipse.org/New_Maven_Coordinates 和 Maven Central 从 Java 8 迁移到 Java 11 并从 EE 切换到最新的 Jakarta 库时,我们在(仍然基于 SOAP)客户端应用程序中遇到以下运行时异常:
Exception in thread "main" javax.xml.ws.WebServiceException: Provider com.sun.xml.internal.ws.spi.ProviderImpl not found
at javax.xml.ws.spi.FactoryFinder$1.createException(FactoryFinder.java:31)
at javax.xml.ws.spi.FactoryFinder$1.createException(FactoryFinder.java:28)
at javax.xml.ws.spi.ServiceLoaderUtil.newInstance(ServiceLoaderUtil.java:73)
at javax.xml.ws.spi.FactoryFinder.find(FactoryFinder.java:82)
at javax.xml.ws.spi.Provider.provider(Provider.java:66)
at javax.xml.ws.Service.<init>(Service.java:82)
at [...]
Caused by: java.lang.ClassNotFoundException: com.sun.xml.internal.ws.spi.ProviderImpl
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:583)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
at javax.xml.ws.spi.ServiceLoaderUtil.nullSafeLoadClass(ServiceLoaderUtil.java:60)
at javax.xml.ws.spi.ServiceLoaderUtil.safeLoadClass(ServiceLoaderUtil.java:93)
at javax.xml.ws.spi.ServiceLoaderUtil.newInstance(ServiceLoaderUtil.java:71)
... 5 more
获取java.lang.ClassNotFoundException:com.sun.xml.internal.ws.spi.ProviderImpl中描述的解决方案尽管定义了依赖项,但不起作用,并且不使用Jakarta。
如果我没记错的话,Jarkarta 库不应该包含"com.sun.xml"。包或引用这样的,但javax.xml.ws.spi.Provider显然仍然引用这样的类:
private static final String DEFAULT_JAXWSPROVIDER =
"com.sun"+".xml.internal.ws.spi.ProviderImpl";
那么,有谁知道是否有一个雅加达等效于包含 ProviderImpl 的缺失库,或者我如何解决雅加达的问题?
提前感谢!
我终于找到了解决问题的方法。根据如何在Java 11上使用Web服务中给出的答案?软件包javax.jws不存在JAX-WS的参考实现应该包含在 Java 11 中:
<dependency>
<groupId>com.sun.xml.ws</groupId>
<artifactId>jaxws-ri</artifactId>
<version>2.3.2</version>
<type>pom</type>
</dependency>
不幸的是,使用最新的 maven-compile-plugin 3.8.0 使用此依赖项编译我们的项目会导致 https://jira.apache.org/jira/browse/MCOMPILER-355 中所述的异常。它应该在 3.8.1 中修复,但版本尚不可用。
作为一种解决方法,我让我们的项目使用Get java.lang.ClassNotFoundException中给出的提示:com.sun.xml.internal.ws.spi.ProviderImpl,尽管定义了依赖项,并结合了额外的依赖项(即在jaxws-ri的pom.xml中链接的解析器)以避免随后的java.lang.ClassNotFoundException:com.sun.org.apache.xml.internal.resolver.CatalogManager:
<dependency>
<groupId>com.sun.xml.ws</groupId>
<artifactId>rt</artifactId>
<version>2.3.2</version>
</dependency>
<dependency>
<groupId>com.sun.org.apache.xml.internal</groupId>
<artifactId>resolver</artifactId>
<version>20050927</version>
</dependency>
也许这有助于遇到同样问题的人。
把我的 5 美分扔进戒指,因为我有"同样的问题"。对我来说,解决问题的是坚持使用 jaxws-rt 软件包的第二个版本,因为版本 3.0.0 确实失败了,结果与上面提到的相同。
因此,我用来让我的JDK 8源代码运行而无需任何修改的是:
// https://mvnrepository.com/artifact/com.sun.xml.ws/jaxws-rt
implementation group: 'com.sun.xml.ws', name: 'jaxws-rt', version: '2.3.3' //3.0.0 did not work!
// https://mvnrepository.com/artifact/javax.xml.ws/jaxws-api
implementation group: 'javax.xml.ws', name: 'jaxws-api', version: '2.3.1'
// https://mvnrepository.com/artifact/javax.jws/javax.jws-api
implementation group: 'javax.jws', name: 'javax.jws-api', version: '1.1'