webserviceA 调用另一个webservice B,A的客户端程序运行报错

国产大和尚 2009-12-14 04:19:56
我要用java写一个web服务,实现多任务文件传输请求的任务转发工作,实际的传输调用主机上的web服务来完成,
现在,我写了两个web服务,一个是用来模拟主机的文件传输的服务,叫copyFileService,另外一个是我的主要工作,就是代理服务,名字叫transFileAgentService.
现在,transFileAgentService中有一个方法,为


public String transFile(String sourceFile,String target){

boolean status=false;
String returnWords="";
String clientUri="";
initHostsList();//首先初始化主机列表
//MessageContext mc = MessageContext.getCurrentMessageContext();

// HttpServletRequest request = (HttpServletRequest) mc.getProperty(HTTPConstants.MC_HTTP_SERVLETREQUEST);
//clientUri=request.getRemoteHost();//获得客户端IP
//测试用****************************************请在测试后删除该语句
clientUri="127.0.0.1";
long length=100000;//(long)((1+new Random().nextInt(2))*1000);//假设的文件长度,实际操作时可由host计算
Task task=new Task(clientUri,sourceFile,target,length);//为确保task的唯一性,包装task类

taskList.add(task);
//注意添加完毕,我们还不能结束直接返回,要继续执行传输任务
//***********************注意实际发布的时候,要用getMinTaskHost()找到任务主机
String host="127.0.0.1";//getMinTaskHost();//找到任务最小的主机

//if(fileExistAlready(host,task))returnWords="您选择的目标路径下已有重名的文件,为确保数据的安全性,请另取文件名再上传,或选择其他目标路径!";

status= doFileTrans(host,task);//向该主机传输文件
if(status)
{
returnWords="文件传输成功!";

}else
returnWords="文件传输失败!";
taskList.remove(task);//如果文件传输成功,将任务从列表中删除。
return returnWords;
}
...........
public boolean doFileTrans(String host,Task task){
//测试,只发布在本机

boolean status=false;
RPCServiceClient serviceClient = null;
try {
serviceClient = new RPCServiceClient();
} catch (AxisFault e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
Options options = serviceClient.getOptions();
// 指定调用WebService的URL
EndpointReference targetEPR = new EndpointReference("http://"+ host +":8080/axis2/services/copyFileService");
options.setTo(targetEPR);

// 指定copy方法的参数值
Object[] opAddEntryArgs = new Object[]{task};
System.out.println( task.getSourceFile()+"$%$%"+task.getTarget());
// 指定copy方法返回值的数据类型的Class对象
Class[] classes = new Class[] {Boolean.class};

// 指定要调用的copy方法及WSDL文件的命名空间
QName opAddEntry = new QName("http://filetrans.geoway.com", "doFileTrans");

try {

status=(Boolean)(serviceClient.invokeBlocking(opAddEntry, opAddEntryArgs, classes)[0]);

} catch (AxisFault e) {

e.printStackTrace();
}
return status;
}

我变了客户端Client.java来测试我的服务,代码如下:

public String transFile(String Source,String target){
String returnStr="";

RPCServiceClient serviceClient = null;
try {
serviceClient = new RPCServiceClient();
} catch (AxisFault e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
Options options = serviceClient.getOptions();
// 指定调用WebService的URL
EndpointReference targetEPR = new EndpointReference("http://127.0.0.1:8080/axis2/services/fileTransAgentService");
options.setTo(targetEPR);

// 指定copy方法的参数值
Object[] opAddEntryArgs = new Object[]{Source,target};

// 指定copy方法返回值的数据类型的Class对象
Class[] classes = new Class[] {String.class};

// 指定要调用的copy方法及WSDL文件的命名空间
QName opAddEntry = new QName("http://service.geoway.com", "transFile");
try {

returnStr=(String)(serviceClient.invokeBlocking(opAddEntry, opAddEntryArgs, classes)[0]);
} catch (AxisFault e) {

e.printStackTrace();
}
return returnStr;
}

运行后台报错
报错信息如下:
[WARN] triggerActionNotSupportedFault: messageContext: [MessageContext: logID=urn:uuid:EC9EDD97A726EBC7391260777730984] problemAction: urn:anonOutInOpResponse
[ERROR] The [action] cannot be processed at the receiver.
org.apache.axis2.AxisFault: The [action] cannot be processed at the receiver.
at org.apache.axis2.addressing.AddressingFaultsHelper.triggerAddressingFault(AddressingFaultsHelper.java:373)
at org.apache.axis2.addressing.AddressingFaultsHelper.triggerActionNotSupportedFault(AddressingFaultsHelper.java:336)
at org.apache.axis2.dispatchers.AddressingBasedDispatcher.checkAction(AddressingBasedDispatcher.java:141)
at org.apache.axis2.dispatchers.AddressingBasedDispatcher.invoke(AddressingBasedDispatcher.java:126)
at org.apache.axis2.engine.Phase.invoke(Phase.java:318)
at org.apache.axis2.engine.AxisEngine.invoke(AxisEngine.java:251)
at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:160)
at org.apache.axis2.transport.http.HTTPTransportUtils.processHTTPPostRequest(HTTPTransportUtils.java:167)
at org.apache.axis2.transport.http.AxisServlet.doPost(AxisServlet.java:142)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
at java.lang.Thread.run(Unknown Source)
org.apache.axis2.AxisFault: The server did not recognise the action which it received:
at org.apache.axis2.handlers.addressing.AddressingInFaultHandler.invoke(AddressingInFaultHandler.java:114)
at org.apache.axis2.engine.Phase.invoke(Phase.java:318)
at org.apache.axis2.engine.AxisEngine.invoke(AxisEngine.java:251)
at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:160)
at org.apache.axis2.description.OutInAxisOperationClient.handleResponse(OutInAxisOperation.java:364)
at org.apache.axis2.description.OutInAxisOperationClient.send(OutInAxisOperation.java:417)
at org.apache.axis2.description.OutInAxisOperationClient.executeImpl(OutInAxisOperation.java:229)
at org.apache.axis2.client.OperationClient.execute(OperationClient.java:165)
at org.apache.axis2.client.ServiceClient.sendReceive(ServiceClient.java:540)
at org.apache.axis2.client.ServiceClient.sendReceive(ServiceClient.java:521)
at org.apache.axis2.rpc.client.RPCServiceClient.invokeBlocking(RPCServiceClient.java:102)
at com.geoway.service.TransFileService.doFileTrans(TransFileService.java:147)
at com.geoway.service.TransFileService.transFile(TransFileService.java:77)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.apache.axis2.rpc.receivers.RPCUtil.invokeServiceClass(RPCUtil.java:194)
at org.apache.axis2.rpc.receivers.RPCMessageReceiver.invokeBusinessLogic(RPCMessageReceiver.java:102)
at org.apache.axis2.receivers.AbstractInOutMessageReceiver.invokeBusinessLogic(AbstractInOutMessageReceiver.java:40)
at org.apache.axis2.receivers.AbstractMessageReceiver.receive(AbstractMessageReceiver.java:114)
at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:173)
at org.apache.axis2.transport.http.HTTPTransportUtils.processHTTPPostRequest(HTTPTransportUtils.java:167)
at org.apache.axis2.transport.http.AxisServlet.doPost(AxisServlet.java:142)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
at java.lang.Thread.run(Unknown Source)
我从网上找了一圈,也没有什么好的解决方法,请教各位大牛,给说说是怎么回事呢?
难到java webservice不能嵌套调用吗?还是需要特殊的配置?
...全文
820 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
fy_kenny 2011-07-22
  • 打赏
  • 举报
回复
你好你的问题解决了吗?

我也遇到这样的问题,请求帮忙

q435579128
zhengxiongh 2011-03-03
  • 打赏
  • 举报
回复
[ERROR] The [action] cannot be processed at the receiver.
服务没有部署好
caijun 2010-07-20
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 brave4108 的回复:]
我在做异步webservice时 遇到了和你一样的问题

报的也是[WARN] triggerActionNotSupportedFault: messageContext: [MessageContext: logID=urn:uuid:EC9EDD97A726EBC7391260777730984] problemAction:.....

我的解决办法是
String axis2……
[/Quote]

我也一样的问题。。 你的方法我试了不行啊 能详细点吗
brave4108 2009-12-17
  • 打赏
  • 举报
回复
我在做异步webservice时 遇到了和你一样的问题

报的也是[WARN] triggerActionNotSupportedFault: messageContext: [MessageContext: logID=urn:uuid:EC9EDD97A726EBC7391260777730984] problemAction:.....

我的解决办法是
String axis2Repo = "C:/Program Files/axis2-1.4.1/repository";
String axis2xml = "C:/Program Files/axis2-1.4.1/samples/userguide/conf/axis2.xml";
ConfigurationContext configContext = ConfigurationContextFactory.createConfigurationContextFromFileSystem(axis2Repo,axis2xml);
ServiceClient serviceClient = new ServiceClient(configContext,null);

其中axis2xml中的axis2.xml文件不是C:\Program Files\axis2-1.4.1\conf\下的axis2.xml

重新配一下ManualServiceStub。在你的代码中应该是重新配置
serviceClient = new RPCServiceClient();
国产大和尚 2009-12-16
  • 打赏
  • 举报
回复
求救!好心人给解答一下吧!
国产大和尚 2009-12-14
  • 打赏
  • 举报
回复
紧急求助,请各位大姐打个帮忙啊!

8,906

社区成员

发帖
与我相关
我的任务
社区描述
XML/XSL相关问题讨论专区
社区管理员
  • XML/XSL社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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