我正在使用 JBoss 5.1.0.GA(用于 JDK6)和 jaxws 2.2.6。当我调用 web 服务时,我得到以下异常:
java.util.ServiceConfigurationError:javax.xml.ws.spi.Provider:提供程序 org.jboss.ws.core.jaxws.spi.ProviderImpl 无法实例化:org.jboss.resource.work.WorkWrapper 处的 java.lang.ClassCastException .completed(WorkWrapper.java:283)
at org.jboss.util.threadpool.BasicTaskWrapper.taskCompleted(BasicTaskWrapper.java:367) at org.jboss.util.threadpool.BasicTaskWrapper.run(BasicTaskWrapper.java:268) at java。 util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 在 java.lang.Thread.run(Thread.java:680)原因:java.util.ServiceConfigurationError:javax.xml.ws.spi.Provider:提供程序 org.jboss.ws.core.jaxws.spi.ProviderImpl 无法实例化:java.util.ServiceLoader 处的 java.lang.ClassCastException。在 java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:353) 在 java.util.ServiceLoader$1.next 的 java.util.ServiceLoader.access$100(ServiceLoader.java:164) 失败(ServiceLoader.java:207) (ServiceLoader.java:421) 在 javax.xml.ws.spi.Provider.provider(Provider.java:140) 在 javax.xml 的 javax.xml.ws.spi.Provider.getProviderUsingServiceLoader(Provider.java:180)。 ws.Service.(Service.java:92)
[...]
... 3 更多原因:java.lang.Class.cast(Class.java:2990) 的 java.util.ServiceLoader 的 java.lang.ClassCastException $LazyIterator.next(ServiceLoader.java:345)
... 14 更多
我还尝试将 jbossws 从 3.1.2.GA 更新到版本 3.4.0,没有任何改变。我已经阅读了很多与检查 JBoss 的 lib/endorsed 中的 jar 相关的建议,所以这是内容:
activation.jar
jaxb-api.jar
jaxws-api.jar
jbossws-native-factories.jar
resolver.jar
serializer.jar stax-api.jar
xalan.jar
xercesImpl.jar
我还在 JVM 中添加了开关 -verbose:class:
[Loaded org.jboss.ws.core.jaxws.spi.ProviderImpl from jar:file:/Users/carlo/jboss-5.1.0.GA/common/lib/jbossws-native-core.jar!/]
并且该类扩展javax.xml.ws.spi.Provider
(http://bit.ly/LK9bNE)
有人可以帮我这里发生了什么吗?
编辑 1
好的,所以我看到 ClassCastException 是从以下位置引发的:ServiceLoader.java 第 345 行
S p = service.cast(Class.forName(cn, true, loader).newInstance());
当调用 service.cast 时,this
isjavax.xml.ws.spi.Provider
和要转换的 arg is org.jboss.ws.core.jaxws.spi.ProviderImpl
。我仍然无法理解这个问题。