Webservice返回java.lang.reflect.InvocationTargetException

时间:2010-06-08 19:25:05

标签: java web-services

我在向java webservice发出请求时收到上述消息。

我们最初创建了一个Java控制台应用程序并手动提交了一个xml文件。将其作为Java应用程序运行时,将使用System.out.println成功创建并显示响应。我们通过选择包含方法的java文件并选择“create webservice”来指定要在其中创建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");

Web服务永远不会到达下一行 - 以下是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中运行web服务并使用SOAPUI提交请求 - 这指向创建Web服务时生成的wsdl。

如果有人对如何解决这个问题有任何帮助或想法,请回复 - 感谢您花时间阅读这篇文章!

2 个答案:

答案 0 :(得分:5)

我和你很相似,通过SOAP接收一些XML并将其编组到对象中。这不一定与问题有关。

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

基本上,您需要将LogHandler添加到WSDD文件中。以下页面介绍了WSDD中您需要的内容。但是这个页面讨论了Axis客户端的client-config.wsdd,而我在我的EAR中绑定了Axis并对server-config.wsdd进行了更改。

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

This page具有更具体的Tomcat信息

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

答案 1 :(得分:0)

我最近遇到过这个问题。当我们无法在我们指向的服务器上找到相关的Java代码时,会发生这种情况。

您可以参考以下几种可能性:

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

•服务器上的WSDL和后续Jar文件已更新,WSDLconsumed不是最新的

•有多个相同的jar文件  键入JAR文件夹。在大多数情况下,用户重命名他们的旧JAR    放置新更新的JAR文件之前的文件。这不应该    完成,因为没有采取正确的方法。所以摆脱所有    来自SERVER的不必要的JAR文件。见下文