SOAP WSDL Generate Code

BasicHttpsBinding_IArasCargoIntegrationService / CallCourier

ASP AutoIt C C (Unicode) C++ C++ (Unicode) C# DataFlex Delphi Foxpro Go Java Node.js Objective-C Perl PHP Extension PowerBuilder Powershell PureBasic Python CkPython Ruby SQL Server Swift TCL VB.NET VB6 VBScript Xojo
$oXml = ObjCreate("Chilkat_9_5_0.Xml")
$oXml.Tag = "soapenv:Envelope"
$oXml.AddAttribute("xmlns:soapenv","http://schemas.xmlsoap.org/soap/envelope/")
$oXml.AddAttribute("xmlns:tem","http://tempuri.org/")
$oXml.UpdateChildContent "soapenv:Header",""
$oXml.UpdateChildContent "soapenv:Body|tem:CallCourier|tem:loginInfo","string"
$oXml.UpdateChildContent "soapenv:Body|tem:CallCourier|tem:queryInfo","string"

; In a SOAP HTTP request, including the XML declaration (<?xml version="1.0" encoding="UTF-8"?>) in the XML body is generally not required. 
$oXml.EmitXmlDecl = False
Local $soapRequestBody = $oXml.GetXml()

Local $sEndpoint = "https://customerservicestest.araskargo.com.tr/ArasCargoIntegrationService.svc"
Local $soapAction = "http://tempuri.org/IArasCargoIntegrationService/CallCourier"
;  For SOAP requests, the standard Content-Type is usually set to "text/xml" or "application/soap+xml"
Local $sContentType = "text/xml"

$oHttp = ObjCreate("Chilkat_9_5_0.Http")

$oHttp.ClearHeaders 
$oHttp.SetRequestHeader "Content-Type",$sContentType
$oHttp.SetRequestHeader "SOAPAction",$soapAction

Local $oResp = $oHttp.PostXml($sEndpoint,$soapRequestBody,"utf-8")
If ($oHttp.LastMethodSuccess = False) Then
    ConsoleWrite($oHttp.LastErrorText & @CRLF)
    ConsoleWrite("Failed to send SOAP request." & @CRLF)
    Exit
EndIf

; Get the XML response body.
$oResponseXml = ObjCreate("Chilkat_9_5_0.Xml")
$oResp.GetBodyXml($oResponseXml)

Local $iStatusCode = $oResp.StatusCode
ConsoleWrite("response status code: " & $iStatusCode & @CRLF)

; If the status code does not indicate succcess, then show the response XML,
; which probably contains error information.
If ($iStatusCode <> 200) Then
    ConsoleWrite($oResponseXml.GetXml() & @CRLF)
    Exit
EndIf

ConsoleWrite($oResponseXml.GetXml() & @CRLF)

; Parse the successful SOAP response XML.

; This is a sample of the response XML, but the namespace prefixes will be different.
; We can parse the result using "*" for the namespace prefixes (see below).

Local $iCount = $oResponseXml.GetChildIntValue("*:Body|*:CallCourierResponse|*:CallCourierResult|*:count")
Local $iResult = $oResponseXml.GetChildIntValue("*:Body|*:CallCourierResponse|*:CallCourierResult|*:result")
Local $sResultMessage = $oResponseXml.GetChildContent("*:Body|*:CallCourierResponse|*:CallCourierResult|*:resultMessage")
Request XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
    <soapenv:Header/>
    <soapenv:Body>
        <tem:CallCourier>
            <tem:loginInfo>string</tem:loginInfo>
            <tem:queryInfo>string</tem:queryInfo>
        </tem:CallCourier>
    </soapenv:Body>
</soapenv:Envelope>
Response XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/" xmlns:cus="http://schemas.datacontract.org/2004/07/CustCargoInfo.Models">
    <soapenv:Header/>
    <soapenv:Body>
        <tem:CallCourierResponse>
            <tem:CallCourierResult>
                <cus:count>1042</cus:count>
                <cus:result>1042</cus:result>
                <cus:resultMessage>string</cus:resultMessage>
            </tem:CallCourierResult>
        </tem:CallCourierResponse>
    </soapenv:Body>
</soapenv:Envelope>