在开发EJBCA 调用其WS接口时候,发生了JAX-WS 2.2 API与Java SE 6冲突的问题。:WSSERVLET11: failed to parse runtime descriptor: java.lang.NoSuchMethodError: javax.xml.ws.WebFault.messageName()Ljava/lang/String;
搜了一下网上都这样说:
一,开发环境:
JDK:jdk-6u22-windows-i586.exe
Eclipse:eclipse-jee-helios-SR1-win32
Tomcat:apache-tomcat-7.0.4.exe
WebService:metro-2_0_1.zip
二,错误信息:
WSSERVLET11: failed to parse runtime descriptor: java.lang.NoSuchMethodError: javax.xml.ws.WebFault.messageName()Ljava/lang/String;
三,错误原因:
参照:http://metro.java.net/guide/Using_JAX_WS_2_x___Metro_1_x_2_0_with_Java_SE_6.html#
Using_Metro_2_0_with_Java_SE_6
说明:Java SE 6 Update Release 4之前的版本中包含的JAX-WS版本为2.0;
Java SE 6 Update Release 4以及之后的版本中包含的JAX-WS版本为2.1;
Metro2.0中包含的JAX-WS版本为2.2。
程序在运行时优先使用内嵌到Java SE 6中的JAX-WS API,而不是从Metro拷贝到应用程序的
JAX-WS 2.2 API。因此,如果应用程序中使用了JAX-WS 2.2 API,就会在运行时出错。
四,解决方法:
参照metro内的metro-on-tomcat.xml文件,将metro内的JAR包拷贝到如下目录中。(目录不存在则手动创建)
STEP1:将webservices-api.jar拷贝到JAVA_HOME内的jre\lib\endorsed目录。例:
C:\Program Files\Java\jdk1.6.0_22\jre\lib\endorsed\webservices-api.jar
STEP2:将jsr173_api.jar和webservices-api.jar拷贝到Tomcat的endorsed目录。例:
C:\Program Files\Apache Software Foundation\Tomcat 7.0\endorsed\jsr173_api.jar
C:\Program Files\Apache Software Foundation\Tomcat 7.0\endorsed\webservices-api.jar
STEP2:将webservices-extra.jar、webservices-extra-api.jar、webservices-rt.jar
和webservices-tools.jar四个文件拷贝到Tomcat的lib目录。例:
C:\Program Files\Apache Software Foundation\Tomcat 7.0\lib\webservices-extra.jar
C:\Program Files\Apache Software Foundation\Tomcat 7.0\lib\webservices-extra-api.jar
C:\Program Files\Apache Software Foundation\Tomcat 7.0\lib\webservices-rt.jar
C:\Program Files\Apache Software Foundation\Tomcat 7.0\lib\webservices-tools.jar<
P.S. 仅仅在我自己的机器上测试过。暂时还不明白原理。>_<