我在向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.
如果有人对如何解决这个问题有任何帮助或想法,请回复 - 感谢您花时间阅读这篇文章!
我和你很相似,通过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 /目录中.