SOAP API请求适用于Boomerang,但不适用于node-soap

时间:2016-07-21 17:47:28

标签: node.js wcf soap node-soap aramex

我正在尝试访问SOAP API,我可以轻松地使用Boomerang。以下是请求的格式:

<x:Envelope xmlns:x="http://schemas.xmlsoap.org/soap/envelope/" xmlns:v="http://ws.aramex.net/ShippingAPI/v1/" xmlns:arr="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
    <x:Header/>
    <x:Body>
        <v:ShipmentTrackingRequest>
            <v:ClientInfo>
                <v:UserName>myUsernameHere</v:UserName>
                <v:Password>myPasswordHere</v:Password>
                <v:Version>v1.0</v:Version>
                <v:AccountNumber>MyAccNumberHere</v:AccountNumber>
                <v:AccountPin>MyPinHere</v:AccountPin>
                <v:AccountEntity>XYZ</v:AccountEntity>
                <v:AccountCountryCode>XYZ</v:AccountCountryCode>
            </v:ClientInfo>
            <v:Transaction>
                <v:Reference1>001</v:Reference1>
                <v:Reference2>?</v:Reference2>
                <v:Reference3>?</v:Reference3>
                <v:Reference4>?</v:Reference4>
                <v:Reference5>?</v:Reference5>
            </v:Transaction>
            <v:Shipments>
                <arr:string>41496248135</arr:string>
            </v:Shipments>
            <v:GetLastTrackingUpdateOnly>true</v:GetLastTrackingUpdateOnly>
        </v:ShipmentTrackingRequest>
    </x:Body>
</x:Envelope>

请求获取了所有必需的信息。但我想使用node-soap发出相同的请求。这是我的代码:

var soap = require('soap');
var express = require('express');
var app = express();

var url = 'aramex/aramex.wsdl';
var args =  [{
    ClientInfo: 
    {
        UserName: 'myUsernameHere',
        Password: 'myPasswordHere',
        Version: 'v1.0',
        AccountNumber: 'MyAccNumberHere',
        AccountPin: 'MyPinHere',
        AccountEntity: 'XYZ',
        AccountCountryCode: 'XYZ'        
    },
    Transaction: 
      { Reference1: '001' },

    Shipments: ['41496248135']
}];

app.get('/', function(req, res){

soap.createClient(url, function(err, client) {
        client.TrackShipments(args, function(err, result, body) {
          res.send(result);
        });  
    });
})

app.listen(process.env.PORT, process.env.IP, function(){
    console.log("Server Up");
})

我得到的是result中的一个巨大错误。 result对象的主体如下:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/"><s:Body><s:Fault><faultcode xmlns:a="http://schemas.microsoft.com/net/2005/12/windowscommunicationfoundation/dispatcher">a:InternalServiceFault</faultcode><faultstring xml:lang="en-US">Error in deserializing body of request message for operation 'TrackShipments'. OperationFormatter encountered an invalid Message body. Expected to find node type 'Element' with name 'ShipmentTrackingRequest' and namespace 'http://ws.aramex.net/ShippingAPI/v1/'. Found node type 'Element' with name 'ShipmentTrackingRequest' and namespace ''</faultstring><detail><ExceptionDetail xmlns="http://schemas.datacontract.org/2004/07/System.ServiceModel" xmlns:i="http://www.w3.org/2001/XMLSchema-instance"><HelpLink i:nil="true"/><InnerException><HelpLink i:nil="true"/><InnerException i:nil="true"/><Message>OperationFormatter encountered an invalid Message body. Expected to find node type 'Element' with name 'ShipmentTrackingRequest' and namespace 'http://ws.aramex.net/ShippingAPI/v1/'. Found node type 'Element' with name 'ShipmentTrackingRequest' and namespace ''</Message><StackTrace> at System.ServiceModel.Dispatcher.DataContractSerializerOperationFormatter.DeserializeBody(XmlDictionaryReader reader, MessageVersion version, String action, MessageDescription messageDescription, Object[] parameters, Boolean isRequest)&#xD; at System.ServiceModel.Dispatcher.OperationFormatter.DeserializeBodyContents(Message message, Object[] parameters, Boolean isRequest)&#xD; at System.ServiceModel.Dispatcher.OperationFormatter.DeserializeRequest(Message message, Object[] parameters)</StackTrace><Type>System.Runtime.Serialization.SerializationException</Type></InnerException><Message>Error in deserializing body of request message for operation 'TrackShipments'. OperationFormatter encountered an invalid Message body. Expected to find node type 'Element' with name 'ShipmentTrackingRequest' and namespace 'http://ws.aramex.net/ShippingAPI/v1/'. Found node type 'Element' with name 'ShipmentTrackingRequest' and namespace ''</Message><StackTrace> at System.ServiceModel.Dispatcher.OperationFormatter.DeserializeRequest(Message message, Object[] parameters)&#xD; at System.ServiceModel.Dispatcher.DispatchOperationRuntime.DeserializeInputs(MessageRpc&amp; rpc)&#xD; at System.ServiceModel.Dispatcher.DispatchOperationRuntime.InvokeBegin(MessageRpc&amp; rpc)&#xD; at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage5(MessageRpc&amp; rpc)&#xD; at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage11(MessageRpc&amp; rpc)&#xD; at System.ServiceModel.Dispatcher.MessageRpc.Process(Boolean isOperationContextSet)</StackTrace><Type>System.ServiceModel.CommunicationException</Type></ExceptionDetail></detail></s:Fault></s:Body></s:Envelope>

如何解决此问题?

1 个答案:

答案 0 :(得分:0)

如果它仍然相关,我遇到了同样的问题。从Aramex的网站上获取最新的WDSL文件。

请求args应如下所示:

let args =  [{
    ClientInfo: {
        UserName: 'myUsernameHere',
        Password: 'myPasswordHere',
        Version: 'v1.0',
        AccountNumber: 'MyAccNumberHere',
        AccountPin: 'MyPinHere',
        AccountEntity: 'XYZ',
        AccountCountryCode: 'XYZ'        
    },
    "Transaction": {
        "Reference1": "001",
        "Reference2": "002",
        "Reference3": "003",
        "Reference4": "004",
        "Reference5": "005"
    },
    "Shipments": {
            "string": awb
    },
    "GetLastTrackingUpdateOnly": false]
}];

您获得的错误主要是因为wsdl解析器无法将我们的args列表与WSDL文件中定义的内容进行匹配。