最近将weblogic(wlserver_10.3)装在jdk1.7上面发现之前的应用不能够deploy上去了,

老是报错

java.lang.ClassCastException: weblogic.wsee.jaxws.spi.WLSEndpoint cannot be cast to org.apache.cxf.jaxws.EndpointImpl

一开始以为是cxf与jdk1.7不兼容引起的,CXF官网上也没有明确说明它与jdk1.7的兼容性。最后还是在weblogic的官方文档(http://docs.oracle.com/cd/E23943_01/doc.1111/e14142/jdk7.htm)上找到了答案,原来weblogic g11明确指出了它与jdk1.7的兼容问题,提出了解决方案:将weblogic安装目录下%WL_HOME%/modules下的三个jar包

javax.annotation_1.0.0.0_1-0.jar

javax.xml.bind_2.1.1.jar

javax.xml.ws_2.1.1.jar

拷贝到%JAVA_HOME%/jre/lib/endorsed(如果没有请创建)下即可解决weblogic与jdk1.7之间的兼容问题。

出现这一情况的原因是Java Endorsed Standards Override Mechanism这一机制的存在。简单来说就是Java开放了一些类和接口来允许第三方自由实现,提高了自定义和灵活性。这些类和接口包括JAXP(XML processing),JAXB(XML binding)等。拿WebService API来举例,Java自身有一套实现机制,而例如WebLogic也有自己的实现机制,当JDK升级后两套机制不能够兼容会出现如上的问题。解决方法很简单,就是让JDK也使用WebLogic的WebService机制,将相应的jar包放入jdk默认的endorsed目录下即可。具体的原理和其他可重写的接口见http://docs.oracle.com/javase/6/docs/technotes/guides/standards/