Webservice返回java.lang.reflect.InvocationTargetException。

3

当我向Java Web服务发出请求时,我收到了上述消息。

我们最初创建了一个Java控制台应用程序,并手动提交了一个xml文件。当将其作为Java应用程序运行时,通过使用System.out.println成功创建和显示响应。我们通过选择包含方法的Java文件并选择“创建Web服务”,指定要在其中创建Web服务的动态项目以及要公开的方法来创建Web服务。

该应用程序所做的是使用以下方法将xml文件解组到对象中:

 public static Object unmarshalToObject(Class classToBeBound,
   String xmlRequest) {
  Object obj = new Object();
  try {
   JAXBContext jc = JAXBContext.newInstance(classToBeBound);
   Unmarshaller um = jc.createUnmarshaller();
   obj = um.unmarshal(new StringReader(xmlRequest));
  } catch (Exception e) {
   e.printStackTrace()
  }
  return obj;
 }

对文件进行一些处理,然后将对象编组为XML,如下所示:

 public static String marshalToXML(Object data) {
  StringWriter sw = new StringWriter();
  try {
   logger.info("Create new Marshall");
   JAXBContext jc = JAXBContext.newInstance("ContextPathName");
   logger.info("Marshalled to xmlObjects");
   Marshaller marshaller = jc.createMarshaller();
   marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
   marshaller.setProperty(Marshaller.JAXB_FRAGMENT, true);
   marshaller.marshal(data, sw);
  } catch (Exception e) {
   logException(logger, e);
  }
  return sw.toString();
 }

以下是似乎引起问题的代码行,因为记录器在此之前显示了消息:
JAXBContext jc = JAXBContext.newInstance("ContextPathName");

这个webservice无法继续执行下一行代码——以下是SOAP消息体:

  <soapenv:Fault>
     <faultcode>soapenv:Server.userException</faultcode>
     <faultstring>java.lang.reflect.InvocationTargetException</faultstring>
     <detail>
        <ns1:hostname xmlns:ns1="http://xml.apache.org/axis/">servername</ns1:hostname>
     </detail>
  </soapenv:Fault>

我已经在这段代码周围添加了Try/Catch,甚至寻找JAXBExceptions,但似乎没有捕获任何异常 - 通用异常也是如此。
运行控制台应用程序时不会出现此问题。其中包括sun\jwsdp-2.0\jaxb\lib文件夹下的以下内容的构建路径:
jaxb-api.jar
jsr173_1.0_api.jar
jaxb-impl.jar

我已经将它们添加到动态项目的WEB-INF文件夹中的lib文件夹中。
我正在JBuilder 2008 R2中运行webservice,并使用SOAPUI提交请求 - 这指向创建webservice时生成的wsdl。
如果有人对如何解决此问题有任何帮助或想法,请回复 - 感谢您抽出时间阅读此帖!

1
该SOAP故障指示服务器上的错误,这个错误没有被正确处理和报告。它可能是由于您的请求中出现了一些问题,但是如果没有适当的错误报告,就无法确定具体是什么问题。 - skaffman
你的问题解决了吗? - Bill Mote
2个回答

5

我正在做和你相似的事情,通过SOAP接收一些XML并将其转换为对象。这与问题无关。

当在Axis中运行某些Java代码处理请求时出现问题时,会抛出InvocationException。您需要指定一些额外的选项才能访问来自Axis本身的日志输出。一旦您拥有了这个输出,很可能会看到一个异常,这对您来说是有意义的(在我的情况下,我使用了一个没有包含在服务器类路径上的类)。

基本上,您需要向WSDD文件添加LogHandler。以下页面对WSDD中所需内容有很好的介绍。但是,该页面讨论了用于Axis客户端的client-config.wsdd,而我将Axis捆绑在我的EAR中,并对server-config.wsdd进行了更改。

http://www.theserverside.com/discussions/thread.tss?thread_id=35765

此页面提供了更多针对Tomcat的具体信息

请注意,axis.log的保存位置可能因您的服务器和操作系统而异。有些人报告它出现在Windows的System32目录中,第二个链接说它将出现在Tomcat的bin/目录中。在我的情况下(Mac OS X,Glassfish 2.1.1),它出现在我的域的config/目录中。


0

我最近遇到了这个问题。这通常是在我们无法在所指向的服务器上找到相关的Java代码时发生。

以下是您可以考虑的一些可能性:

• 服务器上不存在正确的JAR文件

• WSDL及其后续Jar文件已更新,而所使用的WSDL不是最新版本

• JAR文件夹中存在多个相同类型的jar文件。在大多数情况下,用户会在放置新更新的JAR文件之前重命名旧的JAR文件,这样做是错误的,因为不会选择正确的方法。因此,请从服务器上删除所有不必要的JAR文件。请参见以下说明。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接