Заголовок мыла Amadeus с указанием состояния 4 у почтальона - PullRequest
0 голосов
/ 03 сентября 2018

Я пытаюсь связаться с помощью мыла API amadeus, используя https://www.getpostman.com/. Так что я сделал свой запрос Soap Header v4 в соответствии с их документацией, однако я всегда получаю SoapFault "11 | Session |"

Я также устанавливаю HTTP-заголовок SOAPAction в http://webservices.amadeus.com/VLSSLQ_06_1_1A в этом случае.

Когда я использую таких клиентов, как https://github.com/amabnl/amadeus-ws-client, это работает, но при попытке выполнить тот же запрос с помощью почтальона - нет, есть идеи?

Запрос

<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
                   xmlns:ns1="http://xml.amadeus.com/VLSSLQ_06_1_1A"
                   xmlns:ns2="http://www.w3.org/2005/08/addressing"
                   xmlns:ns3="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wsswssecurity-secext-1.0.xsd"
                   xmlns:ns4="http://xml.amadeus.com/2010/06/Session_v3"
                   xmlns:ns5="http://xml.amadeus.com/2010/06/Security_v1">
    <SOAP-ENV:Header>
        <ns2:MessageID>x-x-x-x-x</ns2:MessageID>
        <ns2:Action>http://webservices.amadeus.com/VLSSLQ_06_1_1A</ns2:Action>
        <ns2:To>https://nodeD1.test.webservices.amadeus.com/AAAAAAAAA</ns2:To>
        <oas:Security xmlns:oas="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
            <oas:UsernameToken xmlns:oas1="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" oas1:Id="UsernameToken-1">
                <oas:Username>AAAAAAAAA</oas:Username>
                <oas:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">aaaaaa==</oas:Nonce>
                <oas:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordDigest">aaaaa=</oas:Password>
                <oas1:Created>2018-08-28T08:46:39:293Z</oas1:Created>
            </oas:UsernameToken>
        </oas:Security>
        <ns4:Session TransactionStatusCode="Start"/>
        <ns5:AMA_SecurityHostedUser>
            <ns5:UserID POS_Type="1" PseudoCityCode="AABBBCCDDEE" AgentDutyCode="AA" RequestorType="U"/>
        </ns5:AMA_SecurityHostedUser>
    </SOAP-ENV:Header>
    <SOAP-ENV:Body>
        <!-- actual request -->
    </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

Ответ

<?xml version="1.0" encoding="UTF-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:awsse="http://xml.amadeus.com/2010/06/Session_v3" xmlns:wsa="http://www.w3.org/2005/08/addressing">
    <soap:Header>
        <wsa:To>http://www.w3.org/2005/08/addressing/anonymous</wsa:To>
        <wsa:From>
            <wsa:Address>https://nodeD1.test.webservices.amadeus.com/AAAAAAAAA</wsa:Address>
        </wsa:From>
        <wsa:Action>http://webservices.amadeus.com/VLSSLQ_06_1_1A</wsa:Action>
        <wsa:MessageID>urn:uuid:x-x-x-x-x</wsa:MessageID>
        <wsa:RelatesTo RelationshipType="http://www.w3.org/2005/08/addressing/reply">yyyyyy-xxxxx</wsa:RelatesTo>
        <awsse:Session TransactionStatusCode="End">
            <awsse:SessionId>xxxxx</awsse:SessionId>
            <awsse:SequenceNumber>1</awsse:SequenceNumber>
            <awsse:SecurityToken>xxxxx</awsse:SecurityToken>
        </awsse:Session>
    </soap:Header>
    <soap:Body>
        <soap:Fault>
            <faultcode>soap:Client</faultcode>
            <faultstring> 11|Session|</faultstring>
        </soap:Fault>
    </soap:Body>
</soap:Envelope>

Ответы [ 2 ]

0 голосов
/ 04 декабря 2018

Я выяснил, что здесь не так, я использовал информацию о безопасности в Soap-Header (v4) AND в теле для самого запроса Security_Authenticated.

Я удалил все Security-Headers, таким образом, он работает просто отлично, поэтому рабочий запрос выглядит так:

<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
               xmlns:ns1="http://xml.amadeus.com/VLSSLQ_06_1_1A" xmlns:ns2="http://www.w3.org/2005/08/addressing"
               xmlns:ns3="http://xml.amadeus.com/2010/06/Session_v3">
<SOAP-ENV:Header>
    <ns2:MessageID>X</ns2:MessageID>
    <ns2:Action>http://webservices.amadeus.com/VLSSLQ_06_1_1A</ns2:Action>
    <ns2:To>X</ns2:To>
    <ns3:Session TransactionStatusCode="Start">
    </ns3:Session>
</SOAP-ENV:Header>
<SOAP-ENV:Body>
    <ns1:Security_Authenticate>
        <ns1:userIdentifier>
            <ns1:originIdentification>
                <ns1:sourceOffice>X</ns1:sourceOffice>
            </ns1:originIdentification>
            <ns1:originatorTypeCode>x</ns1:originatorTypeCode>
            <ns1:originator>X</ns1:originator>
        </ns1:userIdentifier>
        <ns1:dutyCode>
            <ns1:dutyCodeDetails>
                <ns1:referenceQualifier>X</ns1:referenceQualifier>
                <ns1:referenceIdentifier>X</ns1:referenceIdentifier>
            </ns1:dutyCodeDetails>
        </ns1:dutyCode>
        <ns1:systemDetails>
            <ns1:organizationDetails>
                <ns1:organizationId>X</ns1:organizationId>
            </ns1:organizationDetails>
        </ns1:systemDetails>
        <ns1:passwordInfo>
            <ns1:dataLength>0</ns1:dataLength>
            <ns1:dataType>X</ns1:dataType>
            <ns1:binaryData>X</ns1:binaryData>
        </ns1:passwordInfo>
    </ns1:Security_Authenticate>
</SOAP-ENV:Body>

0 голосов
/ 12 ноября 2018

Поскольку вы получаете ошибку 11|Session|, это означает, что вы отправляете неверные данные. Мало что нужно проверить.

  • Дата и время в часовом поясе "Зулу", потому что Amadeus проверяет время по времени, так что допускается разница только во времени 30 минут.
  • Алгоритм дайджеста пароля.
  • Использование того же самого nonce в течение 30 минут.
...