7

Mam problem z budowaniem klienta mydła za pomocą savon w szynach 3.1. Ale jestem w stanie pomyślnie uzyskać odpowiedź, gdy próbuję wykonać żądanie z wiersza polecenia curl. Moja prośba curl z wiersza polecenia wyglądać takRails 3.1 Prośba o mydło Savon dając Timeout :: Błąd: Timeout :: Błąd ut za pomocą curl otrzymuję odpowiedź

curl -d @Downloads/test.xml -H "content-type: text/xml;charset=UTF-8" -H "SOAPAction: http://services.bamnetworks.com/registration/identityPoint/create" "https://qaservices.bamnetworks.com/ws/services/IdentityPointService" -v 

Z którego mam doskonałą odpowiedź tak.

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><soapenv:Header /><soapenv:Body><identityPoint_create_response xmlns="http://services.bamnetworks.com/registration/types/1.6"><status><code>-2000</code><message> [Duplicate credential constraint violated] [com.bamnetworks.registration.types.exception.DuplicateCredentialException]</message><exceptionClass>com.bamnetworks.registration.types.exception.DuplicateCredentialException</exceptionClass> 

Ale gdy próbuję złożyć wniosek klienta Savon za każdym razem otrzymuję

HTTPI executes HTTP POST using the net_http adapter 
Timeout::Error: Timeout::Error 

Moja prośba Savon wyglądać następująco

client = Savon::Client.new do |wsdl, http| 
    http.auth.ssl.verify_mode = :none 
    wsdl.document = "https://qaservices.bamnetworks.com/ws/services/IdentityPointService?wsdl" 
end 

begin 

response = client.request :ns, :identityPoint_create_request do |soap, wsdl, http| 

     http.headers['SOAPAction'] = 'http://services.bamnetworks.com/registration/identityPoint/create' 
     http.headers = { "Content-Length" => "0", "Connection" => "Keep-Alive" } 
     soap.namespaces["xmlns:ns0"]="http://services.bamnetworks.com/application/types/1.0" 

     soap.header = { 
      "ns0:appCredentials" => { 
       "ns0:name"=>"XXXXXXX", 
       "ns0:password"=>"XXXXXXXXX" 
      } 
     } 
     soap.body ={ 
      :identification => { 
       :email => { 
        :address => "[email protected]" 
       }, 
       :password => { :address => { :id => 44 } } 
      }, 
      :profileProperty => { 

       :name => "birthDay", 
       :value => "17" 
      }, 
      :profileProperty =>  { 
       :name => "birthMonth", 
       :value => "8" 
      }, 
      :profileProperty =>  { 
       :name => "birthYear", 
       :value => "1986" 
      }, 
      :attributes! => { :identification => { :type => "email-password" } } 
     } 
    end 

nie wiem, gdzie jestem popełnienie błędu. Jeśli ktokolwiek mi pomoże w tym, żeby to zrozumieć. Dzięki!

+0

Próbowałeś ustawić limit czasu do większej liczby? Możesz zajrzeć do tego pytania http://stackoverflow.com/questions/6384230/how-to-set-savon-default-timeout-value –

Odpowiedz

0

To może być problem serwer mydło starają się komentować linię:

http.headers = { "Content-Length" => "0", "Connection" => "Keep-Alive" }