2013-06-26 27 views
0

我已经创建了WSO2 ESB作为一个API:得到错误而envoking休息API URL

<api xmlns="http://ws.apache.org/ns/synapse" name="getUUIDAPI" context="/getUUID"> 
    <resource methods="GET" uri-template="?Name={searchValue}" inSequence="getUUIDIN" outSequence="CommonJsonOut"/> 
</api> 

,这让我的API调用URL为http://10.224.64.97:8280/getUUID。现在,当我在我的浏览器试试这个休息服务为:

http://10.224.64.97:8280/getUUID?Name=uvu 

,在ESB我得到的错误是:

TID: [0] [ESB] [2013-06-26 10:25:50,796] ERROR {org.apache.axis2.description.ClientUtils} - The system cannot infer the transport information from the 
/getUUID?Name=uvu?Name=uvu URL. {org.apache.axis2.description.ClientUtils} 
TID: [0] [ESB] [2013-06-26 10:25:50,796] ERROR {org.apache.synapse.core.axis2.Axis2Sender} - Unexpected error during sending message out {org.apache.synapse.core.axis2.Axis2Sender} 
org.apache.axis2.AxisFault: The system cannot infer the transport information from the /getUUID?Name=uvu?Name=uvu URL. 
    at org.apache.axis2.description.ClientUtils.inferOutTransport(ClientUtils.java:81) 
    at org.apache.synapse.core.axis2.DynamicAxisOperation$DynamicOperationClient.executeImpl(DynamicAxisOperation.java:115) 
    at org.apache.axis2.client.OperationClient.execute(OperationClient.java:149) 
    at org.apache.synapse.core.axis2.Axis2FlexibleMEPClient.send(Axis2FlexibleMEPClient.java:456) 
    at org.apache.synapse.core.axis2.Axis2Sender.sendOn(Axis2Sender.java:57) 
    at org.apache.synapse.core.axis2.Axis2SynapseEnvironment.send(Axis2SynapseEnvironment.java:316) 
    at org.apache.synapse.endpoints.AbstractEndpoint.send(AbstractEndpoint.java:329) 
    at org.apache.synapse.endpoints.WSDLEndpoint.send(WSDLEndpoint.java:69) 
    at org.apache.synapse.endpoints.IndirectEndpoint.send(IndirectEndpoint.java:54) 
    at org.apache.synapse.mediators.builtin.SendMediator.mediate(SendMediator.java:95) 
    at org.apache.synapse.mediators.AbstractListMediator.mediate(AbstractListMediator.java:71) 
    at org.apache.synapse.mediators.base.SequenceMediator.mediate(SequenceMediator.java:114) 
    at org.apache.synapse.rest.Resource.process(Resource.java:306) 
    at org.apache.synapse.rest.API.process(API.java:308) 
    at org.apache.synapse.rest.RESTRequestHandler.dispatchToAPI(RESTRequestHandler.java:76) 
    at org.apache.synapse.rest.RESTRequestHandler.process(RESTRequestHandler.java:63) 
    at org.apache.synapse.core.axis2.Axis2SynapseEnvironment.injectMessage(Axis2SynapseEnvironment.java:182) 
    at org.apache.synapse.core.axis2.SynapseMessageReceiver.receive(SynapseMessageReceiver.java:83) 
    at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:180) 
    at org.apache.synapse.transport.passthru.ServerWorker.processNonEntityEnclosingRESTHandler(ServerWorker.java:367) 
    at org.apache.synapse.transport.passthru.ServerWorker.run(ServerWorker.java:204) 
    at org.apache.axis2.transport.base.threads.NativeWorkerPool$1.run(NativeWorkerPool.java:172) 
    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:722) 

正如你可以在上面的错误看到它被击中网址是/getUUID?Name=uvu?Name=uvu但我正在发送/getUUID?Name=uvu。 为什么我得到这个奇怪的错误?如果我复制api文件,与api相关的序列到其他服务器的esb,然后我打上面的url我得到的回应。 请帮助我。在此先感谢

回答

0

定义类似这样;

uri-template="/{searchValue}" 
+0

我做过这样也拉瑟但是当我再次调用服务,即/ getUUID/UVU它是/ getUUID/UVU/UVU – Roy

+0

有点怪异你说的这最后的意思同样的事情..声明? “如果我复制api文件,与api相关的序列到其他服务器的esb,然后我点击上面的url我得到的回应” – Ratha

+0

我的意思是说,如果我复制api的序列和端点从一个系统到另一个有时它在我的系统中,我创建了10个工作正常的api,但是当我将这些api移动到服务器时,我收到了上述发布的错误 – Roy