问题:namespace mismatch require http://manager.service.sc.project.base.com found none
AxisFault
faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server
faultSubcode:
faultString: namespace mismatch require http://manager.service.sc.project.base.com found none
faultActor:
faultNode:
faultDetail:
{http://xml.apache.org/axis/}stackTrace:namespace mismatch require http://manager.service.sc.project.base.com found none
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 com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(AbstractSAXParser.java:609)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanEndElement(XMLDocumentFragmentScannerImpl.java:1782)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2973)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:606)
at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:117)
at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:510)
at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:848)
at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:777)
at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141)
at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1213)
at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(SAXParserImpl.java:648)
at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl.parse(SAXParserImpl.java:332)
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 com.cqupt.thrift.impl.WebserviceUtil.processWebserviceRequest(WebserviceUtil.java:200)
at com.cqupt.thrift.impl.WebserviceUtil.postIWebserviceData(WebserviceUtil.java:175)
at com.cqupt.thrift.impl.IThriftProcess1647.process(IThriftProcess1647.java:61)
at com.cqupt.thrift.methodtest.get(methodtest.java:4595)
at com.acpl.pub.thrift.Monitor$Processor$get.getResult(Monitor.java:352)
at com.acpl.pub.thrift.Monitor$Processor$get.getResult(Monitor.java:1)
at org.apache.thrift.ProcessFunction.process(ProcessFunction.java:32)
at org.apache.thrift.TBaseProcessor.process(TBaseProcessor.java:34)
at org.apache.thrift.server.TThreadPoolServer$WorkerProcess.run(TThreadPoolServer.java:176)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:745)
解决方案:
原来代码如下:将原来的调用 webserviceCall.setOperationName(invokeMethod); 更改为webserviceCall.setOperationName(new QName(sssoapxmlns,invokeMethod));
private static String processWebserviceRequest(String webserviceUrl,String invokeMethod,String parmeter)throws ServiceException, RemoteException{
///转发xml数据请求Webservice接口
///创建服务对象
Service webservice = new Service();
Call webserviceCall = (Call) webservice.createCall();
///设置访问操作点
webserviceCall.setTargetEndpointAddress(webserviceUrl);
///设置操作名,联调时修改
webserviceCall.setOperationName(invokeMethod);
///设置返回类
// webserviceCall.setReturnClass(String.class);
///执行接口,获取执行结果数据
String resultMsg = (String) webserviceCall.invoke(new Object[]{parmeter});
if(resultMsg == null || resultMsg.isEmpty()){
resultMsg = "";
logger.error("请求Webservice接口失败,获取数据为空...");
}
return resultMsg;
}
更改后的代码:
private static String processWebserviceRequest(String webserviceUrl,String invokeMethod,String parmeter)throws ServiceException, RemoteException{
String sssoapxmlns = "http://manager.service.sc.project.base.com";
///转发xml数据请求Webservice接口
///创建服务对象
Service webservice = new Service();
Call webserviceCall = (Call) webservice.createCall();
///设置访问操作点
webserviceCall.setTargetEndpointAddress(webserviceUrl);
///设置操作名,联调时修改
webserviceCall.setOperationName(new QName(sssoapxmlns,invokeMethod));
///设置返回类
// webserviceCall.setReturnClass(String.class);
///执行接口,获取执行结果数据
String resultMsg = (String) webserviceCall.invoke(new Object[]{parmeter});
if(resultMsg == null || resultMsg.isEmpty()){
resultMsg = "";
logger.error("请求Webservice接口失败,获取数据为空...");
}
return resultMsg;
}