我尝试将savon的回复解析为nokokiri文档
c = Savon.client(wsdl: 'http://test.fedresurs.ru/MessageService/WebService.svc?wsdl', digest_auth: ['demowebuser', 'Ax!761BN'], namespace: "http://tempuri.org/", namespace_identifier: :tem, log: true)
r = c.call(:get_trade_messages, message: {'tem:startFrom' => DateTime.now-1})
r.doc.search("TradePlace")
,它返回一个空数组。
我做错了什么?也许我应该以某种方式处理名称空间?但是,如何?我在nokogiri文档中找到的示例使用Xpath,而不是搜索。即使使用Xpath,它也会返回一个空数组。
XML响应:
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<GetTradeMessagesResponse xmlns="http://tempuri.org/">
<GetTradeMessagesResult>
<TradePlace INN="7606055642" Name="Первая электронная площадка " Site="1torgi.ru " OwnerName="ООО "Промтех"">
<TradeList>
<Trade ID_External="ЗКОФЦП-17136" ID_EFRSB="653476">
<MessageList>
<TradeMessage ID="4851134"/>
<TradeMessage ID="4851135"/>
</MessageList>
</Trade>
</TradeList>
</TradePlace>
</GetTradeMessagesResult>
</GetTradeMessagesResponse>
</s:Body>
</s:Envelope>
答案 0 :(得分:0)
您可以使用Nokogiri
来分解XML响应。
一个(现在不起作用)的例子是这样的:
doc = Nokogiri::XML(response.to_hash[:get_quote_response][:get_quote_result])
print doc.to_xml(indent: 2)
print "Date : ", doc.at_css("Date").text, "\n"
print "Last price: ", doc.at_css("Last").text
是我的binbin https://pastebin.com/W0RUuaHU中更完整的示例。不幸的是,WebserviceX已停产。
答案 1 :(得分:0)
正如我期望的那样,答案是在名称空间中,以下代码可以正常工作:
r.doc.search("a|TradePlace", {"a" => "http://tempuri.org/"})