最近将weblogic(wlserver_10.3)装在jdk1.7上面发现以前的应用不可以deploy上去了,总是报错java
java.lang.ClassCastException: weblogic.wsee.jaxws.spi.WLSEndpoint cannot be cast to org.apache.cxf.jaxws.EndpointImplweb
一开始觉得是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包apache
javax.annotation_1.0.0.0_1-0.jar
oracle
javax.xml.bind_2.1.1.jar
ide
javax.xml.ws_2.1.1.jar
ui
拷贝到%JAVA_HOME%/jre/lib/endorsed(若是没有请建立)下既能够解决weblogic与jdk1.7之间的兼容问题。
code
出现这一状况的缘由是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/
server