Webservice返回java.lang.reflect.InvocationTargetException

Dam*_*ian 3 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;
 }
Run Code Online (Sandbox Code Playgroud)

对文件执行一些处理,然后将对象编组为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();
 }
Run Code Online (Sandbox Code Playgroud)

以下是由于记录器在此之前显示消息,似乎导致问题的代码行:

JAXBContext jc = JAXBContext.newInstance("ContextPathName");
Run Code Online (Sandbox Code Playgroud)

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>
Run Code Online (Sandbox Code Playgroud)

我已经在这部分代码中添加了Try/Catch,甚至只要查找JAXBExceptions,但这似乎没有捕获任何东西 - 一般异常也没有.

运行控制台应用程序时不会发生此问题.其构建路径包括sun\jwsdp-2.0\jaxb\lib的以下内容:

jaxb-api.jar
jsr173_1.0_api.jar
jaxb-impl.jar
Run Code Online (Sandbox Code Playgroud)

我已将这些添加到动态项目的WEB-INF文件中的lib文件夹中.

我在JBuilder 2008 R2中运行webservice并使用SOAPUI提交请求 - 这指向创建webservice时生成的wsdl.

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

Rón*_*áin 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

此页面包含更具体的Tomcat信息

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