迁移到雅加达:ClassNotFoundException:com.sun.xml.internal.ws.spi.ProviderImpl

时间:2019-04-18 14:39:13

标签: soap java-11 jakarta-ee

根据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

Getting java.lang.ClassNotFoundException: com.sun.xml.internal.ws.spi.ProviderImpl despite the dependencies are defined中描述的解决方案不起作用,也不使用雅加达。

如果我没记错的话,Jarkarta库中不应包含“ com.sun.xml。”包或引用,但 javax.xml.ws.spi.Provider 显然仍然可以引用此类:

private static final String DEFAULT_JAXWSPROVIDER =
        "com.sun"+".xml.internal.ws.spi.ProviderImpl";

那么,有谁知道是否有一个与缺少的包含ProviderImpl的库等效的雅加达,或者我如何解决雅加达的问题?

谢谢!

2 个答案:

答案 0 :(得分:2)

我终于找到了解决我问题的方法。根据{{​​3}}中给出的答案, 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编译具有此依赖项的项目会导致How to use WebServices on Java 11? package javax.jws does not exist中描述的异常。应该在3.8.1中修复,但是该版本尚不可用。

作为一种解决方法,我让我们的项目使用https://jira.apache.org/jira/browse/MCOMPILER-355中给出的提示,并结合了一个附加的依赖项(即 resolver ,该依赖项也链接在 pom.xml < / em>来避免随后的 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>

也许这可以帮助遇到相同问题的人。

答案 1 :(得分:0)

把我的 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'