недопустимый запрос SOAP требует опытного глаза - PullRequest
0 голосов
/ 27 апреля 2018

TLDR: решение можно найти здесь

Я использую savon для отправки запросов на службу SOAP. Я знаю ... Брутто.

Несмотря на это, мне трудно заставить Савона вести себя. У провайдера SOAP есть этот валидатор, который принимает следующие входные данные:

Web Service: ProductData
Version: 1.0.0
Operation: getProductSellable
Endpoint: https://psproductdata100-stg.pcna.online

Когда я использую валидатор, я ввожу этот xml:

<GetProductSellableRequest xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/">
  <wsVersion xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/">1.0.0</wsVersion>
</GetProductSellableRequest>

И я получаю это тело ответа

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
  <s:Header />
  <s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <GetProductSellableResponse xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/">
      <ErrorMessage xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/">
        <code>110</code>
        <description>Authentication Credentials Required</description>
      </ErrorMessage>
    </GetProductSellableResponse>
  </s:Body>
</s:Envelope>

Этот ответ действителен, потому что я не предоставил свой un / pw. Если я предоставлю учетные данные, я получу полный ответ. Ниже приведен скриншот того, что происходит в моем браузере.

image

Однако, когда я использую Savon, чтобы сделать тот же запрос

#!/usr/bin/env ruby

require 'savon'
require 'awesome_print'
require 'byebug'
require 'pry'

endpoint = 'https://psproductdata100-stg.pcna.online'
path = 'psProductData.svc?singleWsdl'
wsdl = "#{endpoint}/#{path}"

args = {
  wsdl: wsdl,
  log: true,
  log_level: :debug,
  pretty_print_xml: true,
  element_form_default: :qualified
}

client = Savon.client(args) do
  convert_request_keys_to :lower_camelcase
end

message = { ws_version: '1.0.0' }
response = client.call(:get_product_sellable) do
  message(message)
end

ap response

Ответ не возвращается, как ожидалось. XML выглядит близко к тому, что было отправлено валидатором, но не точно.

Вот запрос

D, [2018-04-26T18:01:00.471662 #89854] DEBUG -- : HTTPI /peer GET request to psproductdata100-stg.pcna.online (net_http)
I, [2018-04-26T18:01:00.979809 #89854]  INFO -- : SOAP request: https://psproductdata100-stg.pcna.online/psProductData.svc
I, [2018-04-26T18:01:00.979886 #89854]  INFO -- : SOAPAction: "getProductSellable", Content-Type: text/xml;charset=UTF-8, Content-Length: 501
D, [2018-04-26T18:01:00.980107 #89854] DEBUG -- : <?xml version="1.0" encoding="UTF-8"?>
<env:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/" xmlns:env="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ins0="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/">
  <env:Body>
    <tns:GetProductSellableRequest>
      <tns:wsVersion>1.0.0</tns:wsVersion>
    </tns:GetProductSellableRequest>
  </env:Body>
</env:Envelope>

И ответ

D, [2018-04-26T18:01:00.980224 #89854] DEBUG -- : HTTPI /peer POST request to psproductdata100-stg.pcna.online (net_http)
I, [2018-04-26T18:01:01.650449 #89854]  INFO -- : SOAP response (status 200)
D, [2018-04-26T18:01:01.650731 #89854] DEBUG -- : <?xml version="1.0"?>
<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">
    <GetProductSellableResponse xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/">
      <ErrorMessage xmlns="http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/">
        <code>110</code>
        <description>Version mismatch.</description>
      </ErrorMessage>
    </GetProductSellableResponse>
  </s:Body>
</s:Envelope>

и выход из Савона

{
    :get_product_sellable_response => {
        :error_message => {
                   :code => "110",
            :description => "Version mismatch.",
                 :@xmlns => "http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/"
        },
               :@xmlns => "http://www.promostandards.org/WSDL/ProductDataService/1.0.0/"
    },
                     :"@xmlns:xsi" => "http://www.w3.org/2001/XMLSchema-instance",
                     :"@xmlns:xsd" => "http://www.w3.org/2001/XMLSchema"
}

Ответы [ 3 ]

0 голосов
/ 02 мая 2018

Аналогичная проблема с пространствами имен ruby ​​savon и wsdl namespacing . Я полагаю, у вас та же проблема.

Дополнительное примечание: попробуйте использовать SOAP UI для отладки сгенерированного XML из WSDL и увидите разницу. Также измените XML на XML, сгенерированный из кода, и проверьте XML в пользовательском интерфейсе SOAP. Он покажет ошибки, если таковые имеются в SOAP UI, сделает отладку быстрее и ошибки более понятными.

0 голосов
/ 09 мая 2018

Благодаря другим ответам в этой теме, я нашел этот пост. Я прочитал о том, как работают пространства имен, а также связанные файлы XSD. Объединив мои новые знания с этим постом, я смог создать что-то вроде этого:

require 'savon'
require 'awesome_print'
require 'byebug'
require 'pry'

endpoint = 'https://psproductdata100-stg.pcna.online'
path = 'psProductData.svc?singleWsdl'
wsdl = "#{endpoint}/#{path}"

args = {
  wsdl: wsdl,
  log: false,
  log_level: :debug,
  pretty_print_xml: true,
  element_form_default: :qualified
}

client = Savon.client(args) do
  convert_request_keys_to :lower_camelcase
  namespaces 'xmlns:shar' => 'http://www.promostandards.org/WSDL/ProductDataService/1.0.0/SharedObjects/'
end

message =  {
  'shar:wsVersion' => '1.0.0',
  'shar:id' => 'REDACTED',
  'shar:password' => 'REDACTED'

}
response = client.call(:get_product_sellable) do
  message(message)
end

ap response.body[:get_product_sellable_response][:product_sellable_array][:product_sellable][0..2]

Теперь мне веселее общаться на званых обедах.

0 голосов
/ 01 мая 2018

Я считаю, что ваша проблема связана с пространством имен. WsVersion находится в пространстве имен общего объекта "ins0". Это не в пространстве имен "tns". Попробуйте изменить запрос так, чтобы он выглядел следующим образом:

<env:Body>
  <tns:GetProductSellableRequest>
    <ins0:wsVersion>1.0.0</ins0:wsVersion>
  </tns:GetProductSellableRequest>
</env:Body>
...