调用webservice出现InvocationTargetException

cici_qaz 2011-12-16 10:22:38
问题描述:
自己写了一个webservice的接口,其中有方法去调用其他已经发布的webservice。
自己写的接口一开始都测试过没有问题,但是在方法里面添加逻辑,调用其他webservice的时候出现了问题。

自己写的方法如下:
public boolean isServiceAlive() throws RemoteException {
// TODO Auto-generated method stub
System.out.println("before locator");
IServiceManagerServiceLocator serviceManagerLoc = new IServiceManagerServiceLocator();
System.out.println("after locator");
IServiceManager serviceManager = null;
try {
System.out.println("before service");
serviceManager = serviceManagerLoc.getIServiceManager(new URL("http://120.88.8.52:9000/axis/services/IServiceManager"));
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ServiceException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("after service");
if(serviceManager.listServices()!=null)
{
System.out.println("The ServiceManager is running well!!!");
return true;
}
else
{
System.out.println("The ServiceManager is crashed!!!");
reStart("ServiceManager");
return false;
}
}
用打印语句定位错误,调用的时候,打印了IServiceManagerServiceLocator serviceManagerLoc = new IServiceManagerServiceLocator();之前的“before locator”但是后面的一句没有打印,所以错误应该就是这一句。
错误信息如下:
AxisFault
faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.userException
faultSubcode:
faultString: java.lang.reflect.InvocationTargetException
faultActor:
faultNode:
faultDetail:
{http://xml.apache.org/axis/}hostname:zhangxi-PC

java.lang.reflect.InvocationTargetException
at org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:222)
at org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:129)
at org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1087)
at org.apache.xerces.parsers.AbstractSAXParser.endElement(Unknown Source)
at org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown Source)
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source)
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
at javax.xml.parsers.SAXParser.parse(Unknown Source)
at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227)
at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696)
at org.apache.axis.Message.getSOAPEnvelope(Message.java:435)
at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62)
at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206)
at org.apache.axis.client.Call.invokeEngine(Call.java:2784)
at org.apache.axis.client.Call.invoke(Call.java:2767)
at org.apache.axis.client.Call.invoke(Call.java:2443)
at org.apache.axis.client.Call.invoke(Call.java:2366)
at org.apache.axis.client.Call.invoke(Call.java:1812)
at isLiveMonitor.IsLiveManagerSoapBindingStub.isServiceAlive(IsLiveManagerSoapBindingStub.java:219)
at test.test_jetty.main(test_jetty.java:38)
在网上也搜了很多关于这个错误的回答,有的说是因为缺少jar包,然后我把项目用到的jar包全都放到axis的lib文件夹下,还是不行,希望大家帮着分析一下~
...全文
645 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
tanjinpeng 2012-10-31
  • 打赏
  • 举报
回复
不能用new,要直接声明 private IServiceManagerServiceLocator serviceManagerLoc;然后set get方法

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧