Неожиданное поведение от wso2 esb во время преобразования мыла в остальные
Я создал прокси-сервис с WSO2 ESB и хочу использовать его для предоставления веб-службы REST (от какого-то случайного поставщика) в качестве веб-службы SOAP другому случайному поставщику. Проблема, с которой у меня возникают проблемы, заключается в том, что один из методов мыла просто не работал. Рассматриваемый метод - "myVendorBpmInsereCliente". Что меня действительно смущает, так это то, что метод "myVendorBpmAtualizaCliente", который практически идентичен, работает! Я получаю код ошибки 405 (код ответа http), потому что посредник свойства "REST_URL_POSTFIX", кажется, не добавляет остальную часть пути к URI.
Последовательность:
<proxy xmlns="http://ws.apache.org/ns/synapse" name="cadastroMyVendor" transports="https,http" statistics="enable" trace="enable" startOnLoad="true">
<target>
<inSequence>
<property name="request_action" expression="get-property('Action')"/>
<switch source="get-property('request_action')">
<case regex="myVendorBpmConsultaPeriodo">
<property name="chave" value="myKey" scope="default" type="STRING"/>
<property name="datainicio" expression="//datainicio" scope="default" type="STRING"/>
<property name="datafim" expression="//datafim" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat('consulta/periodo?chave=',get-property('chave'))" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat(get-property('queryparams'),'&datainicio=')" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat(get-property('queryparams'),get-property('datainicio'))" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat(get-property('queryparams'),'&datafim=')" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat(get-property('queryparams'),get-property('datafim'))" scope="default" type="STRING"/>
<property name="REST_URL_POSTFIX" expression="get-property('queryparams')" scope="axis2" type="STRING"/>
<property name="HTTP_METHOD" value="GET" scope="axis2" type="STRING"/>
<log level="full"/>
<case regex="myVendorBpmInsereCliente">
<property name="chave" value="myKey" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat('cliente/novo?chave=',get-property('chave'))" scope="default" type="STRING"/>
<property name="REST_URL_POSTFIX" expression="get-property('queryparams')" scope="axis2" type="STRING"/>
<property name="HTTP_METHOD" value="POST" scope="axis2" type="STRING"/>
<xslt key="conf:/repository/scripts/dropTheSoap.xsl"/>
</case>
<case regex="myVendorBpmAtualizaCliente">
<property name="chave" value="myKey" scope="default" type="STRING"/>
<property name="queryparams" expression="fn:concat('cliente/atualiza?chave=',get-property('chave'))" scope="default" type="STRING"/>
<property name="REST_URL_POSTFIX" expression="get-property('queryparams')" scope="axis2" type="STRING"/>
<property name="HTTP_METHOD" value="PUT" scope="axis2" type="STRING"/>
<xslt key="conf:/repository/scripts/dropTheSoap.xsl"/>
</case>
<default>
<!-- code omitted -->
</default>
</switch>
<send>
<endpoint key="gov:/trunk/endpoints/myKey"/>
<address uri="http://somehost:8080/STL-WS/myVendor/" format="pox"/>
<endpoint key="gov:/trunk/endpoints/myKey"/>
</send>
</inSequence>
<outSequence>
<send/>
</outSequence>
</target>
<description></description>
Вот что я получил от wso2-esb-trace:
16:26:51,090 [-] [HttpClientWorker-10] INFO TRACE_LOGGER End : Send mediator
16:26:51,090 [-] [HttpClientWorker-10] INFO TRACE_LOGGER End : Sequence <anonymous>
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Proxy Service cadastro_myVendor received a new message from : 127.0.0.1
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Message To: /services/cadastro_myVendor
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER SOAPAction: myVendorBpmInsereCliente
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER WSA-Action: myVendorBpmInsereCliente
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Using the anonymous in-sequence of the proxy service for mediation
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Sequence <anonymous>
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Sequence <SequenceMediator> :: mediate()
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Setting property : request_action at scope : default to : myVendorBpmInsereCliente (i.e. result of expression : get-property('Action'))
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Switch mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER XPath : get-property('request_action') evaluates to : myVendorBpmInsereCliente
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Matching case found : myVendorBpmInsereCliente
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Sequence <AnonymousListMediator> :: mediate()
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Setting property : chave at scope : default to : myKey (i.e. constant : myKey)
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Setting property : queryparams at scope : default to : cliente/novo?chave=myKey (i.e. result of expression : fn:concat('cliente/novo?chave=',get-property('chave')))
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Setting property : REST_URL_POSTFIX at scope : axis2 to : cliente/novo?chave=myKey (i.e. result of expression : get-property('queryparams'))
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : XSLT mediator
16:26:51,324 [-] [HttpServerWorker-15] WARN TRACE_LOGGER Warning encountered during stylesheet parsing : javax.xml.transform.TransformerConfigurationException: The attribute axis starting at an attribute node will never select anything
16:26:51,324 [-] [HttpServerWorker-15] WARN TRACE_LOGGER Warning encountered during stylesheet parsing : javax.xml.transform.TransformerConfigurationException: The child axis starting at an attribute node will never select anything
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER output method: xml; encoding: ISO-8859-1
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Using org.apache.synapse.util.jaxp.StreamSourceBuilder
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Using org.apache.synapse.util.jaxp.StreamResultBuilder
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Transformation completed - processing result
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Replace node with result
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : XSLT mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Setting property : HTTP_METHOD at scope : axis2 to : POST (i.e. constant : POST)
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Property mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Start : Send mediator
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER Sending message through endpoint : gov//trunk/endpoints/myVendor resolving to address = http://somehost:8080/STL-WS/myVendor/
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER SOAPAction: myVendorBpmInsereCliente
16:26:51,324 [-] [HttpServerWorker-15] INFO TRACE_LOGGER WSA-Action: myVendorBpmInsereCliente
16:26:51,340 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Send mediator
16:26:51,340 [-] [HttpServerWorker-15] INFO TRACE_LOGGER End : Sequence <anonymous>
16:26:51,355 [-] [HttpClientWorker-11] INFO TRACE_LOGGER Start : Sequence <anonymous>
16:26:51,355 [-] [HttpClientWorker-11] INFO TRACE_LOGGER Sequence <SequenceMediator> :: mediate()
16:26:51,371 [-] [HttpClientWorker-11] ERROR TRACE_LOGGER Error while building message_
Во время другой попытки я добавил собственный медиатор журнала, чтобы записать значение выражения: $axis2:REST_URL_POSTFIX, и в результате я получил то, что ожидал: "cliente/novo? Chave=myKey". Обратите внимание, что я изменил конечную точку в последовательности для иллюстративных целей. Я использую WSO2 ESB версии 4.6.0, работающую как сервис. Любые предложения?
1 ответ
Не могли бы вы изменить формат конечной точки на отдых и проверить, решает ли это проблему.