Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C++) Send SOAP 1.2 Request to Web Service Requiring AuthenticationThis example demonstrates sending a SOAP 1.2 request to a web service that requires both HTTP authentication in the Authorization request header, as well as a service-defined password in the XML body of the request.
#include <CkHttpW.h> #include <CkXmlW.h> #include <CkHttpResponseW.h> void ChilkatSample(void) { // This example assumes the Chilkat HTTP API to have been previously unlocked. // See Global Unlock Sample for sample code. // -------------------------------------------------------------------------------- // Also see Chilkat's Online WSDL Code Generator // to generate code and SOAP Request and Response XML for each operation in a WSDL. // -------------------------------------------------------------------------------- CkHttpW http; // We are sending the following POST: // POST /wsSome_Testes/Service.asmx HTTP/1.1 // Host: www.something.com // Content-Type: application/soap+xml; charset=utf-8 // Content-Length: length // // <?xml version="1.0" encoding="utf-8"?> // <soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope"> // <soap12:Body> // <GetXYZbyABC xmlns="http://tempuri.org/"> // <ABCBEN>string</ABCBEN> // <ABC>string</ABC> // <NumLocal>int</NumLocal> // <Password>string</Password> // <MsgErro>string</MsgErro> // </GetXYZbyABC> // </soap12:Body> // </soap12:Envelope> // // First, specify the login/password for the Authorization request header (not shown in the headers above). http.put_Login(L"YOUR_LOGIN"); // The need for a login domain depends on the web service.. http.put_LoginDomain(L"YOUR_DOMAIN"); http.put_Password(L"YOUR_PASSWORD"); // Build the SOAP XML shown above: // Replace VAL_ABCBEN, VAL_ABC, VAL_NUMLOCAL, and YOUR_SOAP_BODY_PASSWORD with actual values.. CkXmlW xml; xml.put_Tag(L"soap12:Envelope"); xml.AddAttribute(L"xmlns:xsi",L"http://www.w3.org/2001/XMLSchema-instance"); xml.AddAttribute(L"xmlns:xsd",L"http://www.w3.org/2001/XMLSchema"); xml.AddAttribute(L"xmlns:soap12",L"http://www.w3.org/2003/05/soap-envelope"); xml.UpdateAttrAt(L"soap12:Body|GetXYZbyABC",true,L"xmlns",L"http://tempuri.org/"); xml.UpdateChildContent(L"soap12:Body|GetXYZbyABC|ABCBEN",L"VAL_ABCBEN"); xml.UpdateChildContent(L"soap12:Body|GetXYZbyABC|ABC",L"VAL_ABC"); xml.UpdateChildContent(L"soap12:Body|GetXYZbyABC|NumLocal",L"VAL_NUMLOCAL"); xml.UpdateChildContent(L"soap12:Body|GetXYZbyABC|Password",L"YOUR_SOAP_BODY_PASSWORD"); xml.UpdateChildContent(L"soap12:Body|GetXYZbyABC|MsgErro",L"x"); // Set the Content-Type of the request. http.SetRequestHeader(L"Content-Type",L"application/soap+xml"); // We don't need to specify the Content-Length or Host headers. Chilkat automatically adds them. // Send the request... CkHttpResponseW *resp = http.PostXml(L"https://www.something.com/wsSome_Testes/Service.asmx",xml.getXml(),L"utf-8"); if (http.get_LastMethodSuccess() != true) { wprintf(L"%s\n",http.lastErrorText()); return; } wprintf(L"Response Status Code = %d\n",resp->get_StatusCode()); CkXmlW respXml; respXml.LoadXml(resp->bodyStr()); delete resp; wprintf(L"Response XML:\n"); wprintf(L"%s\n",respXml.getXml()); // The response XML should look like this: // <?xml version="1.0" encoding="utf-8"?> // <soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope"> // <soap12:Body> // <GetXYZbyABCResponse xmlns="http://tempuri.org/"> // <GetXYZbyABCResult>int</GetXYZbyABCResult> // <MsgErro>string</MsgErro> // </GetXYZbyABCResponse> // </soap12:Body> // </soap12:Envelope> } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.