我在向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。
如果有人对如何解决这个问题有任何帮助或想法,请回复 - 感谢您花时间阅读这篇文章!
答案 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文件。见下文