Savon을 사용하여 비누의 세계에 들어가고 약간의 문제가 발생했습니다.원시 XML 쿼리를 Savon 2 형식으로 변환
WSDL의는 다음과 같습니다 http://evernet.nwmls.com/evernetqueryservice/evernetquery.asmx?wsdl 그리고이 데이터 공급자의 시험 양식을 사용하는 경우, 나는 다음과 같은 형식을 사용하여 오류없이 데이터를 수신 할 수 있어요 :
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<EverNetQuerySpecification xmlns="urn:www.nwmls.com/Schemas/General/EverNetQueryXML.xsd">
<Message>
<Head>
<UserId>my_username_here</UserId>
<Password>my_password_here</Password>
<SchemaName>StandardXML1_2</SchemaName>
</Head>
<Body>
<Query>
<MLS>nwmls</MLS>
<PropertyType>RESI</PropertyType>
<BeginDate>2014-04-20T00:25:00</BeginDate>
<EndDate>2014-04-22T00:25:00</EndDate>
</Query>
<Filter />
</Body>
를 내가 내 레일 애플 리케이션에서 이것을 복제 할 Savon 2.2와 함께 노력하고 있습니다 :
client = Savon.client(:wsdl => "http://evernet.nwmls.com/evernetqueryservice/evernetquery.asmx?wsdl")
response = client.call(:retrieve_listing_data) do |locals|
locals.message "Query" => {"Head" => {"UserId" => "my_username_here", "Password" => "my_password_here", "SchemaName" => "StandardXML1_2"}, "Body" => {"MLS" => "nwmls", "PropertyType" => "RESI", "BeginDate" => "2014-04-17T00:25:00", "EndDate" => "2014-04-22T00:25:00"}}
end
하지만 나는 오류가 발생하고 있습니다 : 내가 내 Savon 구문 모두를 포함하고있어하지만 뭔가 빠진해야한다는 것 때문에
Value cannot be null. Parameter name: s
나는
... 조금 아무것도 비누에 잃었지만, 특히 여기 손실 편집 해요 : 여기 디버깅을 통한 전체 XML 응답 :
D, [2014-04-22T16:55:52.806716 #77213] DEBUG -- : HTTPI GET request to evernet.nwmls.com (net_http)
I, [2014-04-22T16:55:54.340990 #77213] INFO -- : SOAP request: http://evernet.nwmls.com/evernetqueryservice/evernetquery.asmx
I, [2014-04-22T16:55:54.341077 #77213] INFO -- : SOAPAction: "http://www.nwmls.com/EverNetServices/RetrieveListingData", Content-Type: text/xml;charset=UTF-8, Content-Length: 682
D, [2014-04-22T16:55:54.341120 #77213] 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.nwmls.com/EverNetServices" xmlns:env="http://schemas.xmlsoap.org/soap/envelope/"><env:Body><tns:RetrieveListingData><tns:Query><tns:Head><tns:Head>hoverboard</tns:Head><tns:Password>cP6cHias</tns:Password><tns:SchemaName>StandardXML1_2</tns:SchemaName></tns:Head><tns:Body><tns:MLS>nwmls</tns:MLS><tns:PropertyType>RESI</tns:PropertyType><tns:BeginDate>2014-04-17T00:25:00</tns:BeginDate><tns:EndDate>2014-04-22T00:25:00</tns:EndDate></tns:Body></tns:Query></tns:RetrieveListingData></env:Body></env:Envelope>
D, [2014-04-22T16:55:54.341255 #77213] DEBUG -- : HTTPI POST request to evernet.nwmls.com (net_http)
I, [2014-04-22T16:55:54.678125 #77213] INFO -- : SOAP response (status 200)
D, [2014-04-22T16:55:54.678292 #77213] DEBUG -- : <?xml version="1.0" encoding="utf-8"?><soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"><soap:Body><RetrieveListingDataResponse xmlns="http://www.nwmls.com/EverNetServices"><RetrieveListingDataResult><Listings>
<ResponseMessages>
<Message>Value cannot be null.
Parameter name: s</Message>
</ResponseMessages>
</Listings></RetrieveListingDataResult></RetrieveListingDataResponse></soap:Body></soap:Envelope>
=> #<Savon::Response:0x007f844230e4e0 @http=#<HTTPI::Response:0x007f844230fc00 @code=200, @headers={"cache-control"=>"private, max-age=0", "content-type"=>"text/xml; charset=utf-8", "server"=>"Microsoft-IIS/7.5", "x-aspnet-version"=>"4.0.30319", "x-powered-by"=>"ASP.NET", "date"=>"Tue, 22 Apr 2014 23:55:54 GMT", "content-length"=>"574"}, @raw_body="<?xml version=\"1.0\" encoding=\"utf-8\"?><soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\"><soap:Body><RetrieveListingDataResponse xmlns=\"http://www.nwmls.com/EverNetServices\"><RetrieveListingDataResult><Listings>\r\n <ResponseMessages>\r\n <Message>Value cannot be null.\r\nParameter name: s</Message>\r\n </ResponseMessages>\r\n</Listings></RetrieveListingDataResult></RetrieveListingDataResponse></soap:Body></soap:Envelope>", @body="<?xml version=\"1.0\" encoding=\"utf-8\"?><soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\"><soap:Body><RetrieveListingDataResponse xmlns=\"http://www.nwmls.com/EverNetServices\"><RetrieveListingDataResult><Listings>\r\n <ResponseMessages>\r\n <Message>Value cannot be null.\r\nParameter name: s</Message>\r\n </ResponseMessages>\r\n</Listings></RetrieveListingDataResult></RetrieveListingDataResponse></soap:Body></soap:Envelope>">, @globals=#<Savon::GlobalOptions:0x007f8447489a40 @option_type=:global, @options={:encoding=>"UTF-8", :soap_version=>1, :namespaces=>{}, :logger=>#<Logger:0x007f84474899c8 @progname=nil, @level=0, @default_formatter=#<Logger::Formatter:0x007f84474899a0 @datetime_format=nil>, @formatter=nil, @logdev=#<Logger::LogDevice:0x007f8447489950 @shift_size=nil, @shift_age=nil, @filename=nil, @dev=#<IO:<STDOUT>>, @mutex=#<Logger::LogDevice::LogDeviceMutex:0x007f8447489928 @mon_owner=nil, @mon_count=0, @mon_mutex=#<Mutex:0x007f84474898d8>>>>, :log=>true, :filters=>[], :pretty_print_xml=>false, :raise_errors=>true, :strip_namespaces=>true, :convert_response_tags_to=>#<Proc:[email protected]/Users/seth/.rvm/gems/ruby-2.0.0-p195/gems/savon-2.4.0/lib/savon/options.rb:56 (lambda)>, :multipart=>false, :wsdl=>"http://evernet.nwmls.com/evernetqueryservice/evernetquery.asmx?wsdl"}>, @locals=#<Savon::LocalOptions:0x007f84443732a8 @option_type=:local, @options={:advanced_typecasting=>true, :response_parser=>:nokogiri, :multipart=>false, :message=>{"Query"=>{"Head"=>{"Head"=>"my_username", "Password"=>"my_password", "SchemaName"=>"StandardXML1_2"}, "Body"=>{"MLS"=>"nwmls", "PropertyType"=>"RESI", "BeginDate"=>"2014-04-17T00:25:00", "EndDate"=>"2014-04-22T00:25:00"}}}}>>
팁 주셔서 감사합니다. 내 질문을 전체 응답으로 업데이트했습니다. 나는 200을 얻고있다. 그러나 null이 될 수없는 어떤 가치에 관한 암호가 아니다. – SethS
이제 큰 총을위한 시간입니다 :-). 1 단계 : SoapUI를 사용하여 유효한 요청을 만듭니다. 2 단계 : Ruby/Savon에서 요청을 다시 작성합니다. 이것은 문제를 해결하는 표준 방법 일 것입니다. 분명히 시스템은 의미있는 오류 메시지를 반환하지 않습니다. (불행히도 비정상적이지는 않음). –