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++) BaFin MVP Portal SOAP Web Service MTOMDemonstrate how to send a SOAP request with MTOM attachment to the BaFin MVP Portal as indicated at https://www.bafin.de/SharedDocs/Downloads/EN/dl_mvp-portal_soap_webservice_a26mifir_en.pdf For more information, see https://www.bafin.de/SharedDocs/Downloads/EN/dl_mvp-portal_soap_webservice_a26mifir_en.pdf
#include <CkRestW.h> #include <CkXmlW.h> #include <CkBinDataW.h> void ChilkatSample(void) { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkRestW rest; // Connect to portal.mvp.bafin.de:444 bool bTls = true; int port = 444; bool bAutoReconnect = true; bool success = rest.Connect(L"portal.mvp.bafin.de",port,bTls,bAutoReconnect); if (success != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } // The SOAP request we'll be sending is multipart/related and it will have two parts // 1) the SOAP Envelope // 2) the MTOM attachment (in this case an XML document) // Let's build the SOAP envelope: // Note: The data posted here, including the username, are not actual accounts. It is the sample data provided // at https://www.bafin.de/SharedDocs/Downloads/EN/dl_mvp-portal_soap_webservice_a26mifir_en.pdf // Use this online tool to generate code from sample XML: // Generate Code to Create XML CkXmlW soapXml; soapXml.put_Tag(L"soapenv:Envelope"); soapXml.AddAttribute(L"xmlns:a26mifir",L"http://www.bafin.de/mvp/a26mifir/"); soapXml.AddAttribute(L"xmlns:soapenv",L"http://schemas.xmlsoap.org/soap/envelope/"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security",true,L"soapenv:mustUnderstand",L"1"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security",true,L"xmlns:wsse",L"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security",true,L"xmlns:wsu",L"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurityutility-1.0.xsd"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security|wsse:UsernameToken",true,L"wsu:Id",L"UsernameToken44C3662D584567FE6A14672949268541"); soapXml.UpdateChildContent(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsse:Username",L"karl.meier1234#hg_05_1234567890"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsse:Password",true,L"Type",L"http://docs.oasis-open.org/wss/2004/01/oasis200401-wss-username-token-profile-1.0#PasswordText"); soapXml.UpdateChildContent(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsse:Password",L"XXXXXXXXXX"); soapXml.UpdateAttrAt(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsse:Nonce",true,L"EncodingType",L"http://docs.oasis-open.org/wss/2004/01/oasis200401-wss-soap-message-security1.0#Base64Binary"); soapXml.UpdateChildContent(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsse:Nonce",L"+WifMh5kFw/1fHgMahFu7A=="); soapXml.UpdateChildContent(L"soapenv:Header|wsse:Security|wsse:UsernameToken|wsu:Created",L"2016-06-30T13:55:26.852Z"); soapXml.UpdateChildContent(L"soapenv:Body|a26mifir:submitDATTRA|inDATTRA|a26mifir:dateiname",L"A26MiFIR_Testfile_001.xml"); soapXml.UpdateChildContent(L"soapenv:Body|a26mifir:submitDATTRA|kundenreferenz",L"ClientRef_001"); soapXml.UpdateAttrAt(L"soapenv:Body|a26mifir:submitDATTRA|datei|inc:Include",true,L"href",L"cid:139580394822"); soapXml.UpdateAttrAt(L"soapenv:Body|a26mifir:submitDATTRA|datei|inc:Include",true,L"xmlns:inc",L"http://www.w3.org/2004/08/xop/include"); // We built the following XML: // <?xml version="1.0" encoding="utf-8"?> // <soapenv:Envelope xmlns:a26mifir="http://www.bafin.de/mvp/a26mifir/" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"> // <soapenv:Header> // <wsse:Security soapenv:mustUnderstand="1" xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurityutility-1.0.xsd"> // <wsse:UsernameToken wsu:Id="UsernameToken44C3662D584567FE6A14672949268541"> // <wsse:Username>karl.meier1234#hg_05_1234567890</wsse:Username> // <wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis200401-wss-username-token-profile-1.0#PasswordText">XXXXXXXXXX</wsse:Password> // <wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis200401-wss-soap-message-security1.0#Base64Binary">+WifMh5kFw/1fHgMahFu7A==</wsse:Nonce> // <wsu:Created>2016-06-30T13:55:26.852Z</wsu:Created> // </wsse:UsernameToken> // </wsse:Security> // </soapenv:Header> // <soapenv:Body> // <a26mifir:submitDATTRA> // <inDATTRA> // <a26mifir:dateiname>A26MiFIR_Testfile_001.xml</a26mifir:dateiname> // </inDATTRA> // <kundenreferenz>ClientRef_001</kundenreferenz> // <datei> // <inc:Include href="cid:139580394822" xmlns:inc="http://www.w3.org/2004/08/xop/include"/> // </datei> // </a26mifir:submitDATTRA> // </soapenv:Body> // </soapenv:Envelope> // ------------------------------------------------------------ // We want the top-most header of our request to look like this: // POST https://portal.mvp.bafin.de:444/services/ws/t_a26mifir HTTP/1.1 // Content-Encoding: gzip // Accept-Encoding: gzip,deflate // Content-Type: multipart/related; type="application/xop+xml"; // start="<rootpart@soapui.org>"; start-info="text/xml"; boundary="----=_Part_3_19706996.1467294979823" // SOAPAction: "http://www.bafin.de/mvp/a26mifir/submitDATTRA" // MIME-Version: 1.0 // Transfer-Encoding: chunked // Host: portal.mvp.bafin.de:444 // Connection: Keep-Alive // User-Agent: Apache-HttpClient/4.1.1 (java 1.5) // Some header fields are unimportant. // 1) We can omit the User-Agent. // 2) Also, the Transfer-Encoding doesn't need to be "chunked". It shouldn't matter whether it's chunked or non-chunked. // 3) We do need the Content-Encoding to be "gzip", because the documentation at https://www.bafin.de/SharedDocs/Downloads/EN/dl_mvp-portal_soap_webservice_a26mifir_en.pdf // explicitly states that it wants a gzip compressed request body. // 4) Don't worry about specifying a boundary. Chilkat will auto-generate a boundary and add it to the Content-Type. // 5) If we're sending many requests on the same connection, then set the Connection: Keep-Alive header. Otherwise, there is no need for it. // Begin specifying header fields for the topmost header: rest.AddHeader(L"Content-Type",L"multipart/related; type=\"application/xop+xml\"; start=\"<rootpart@soapui.org>\"; start-info=\"text/xml\""); rest.AddHeader(L"Content-Encoding",L"gzip"); rest.AddHeader(L"Accept-Encoding",L"gzip,deflate"); rest.AddHeader(L"SOAPAction",L"http://www.bafin.de/mvp/a26mifir/submitDATTRA"); rest.AddHeader(L"MIME-Version",L"1.0"); rest.AddHeader(L"Connection",L"Keep-Alive"); // ------------------------------------------------------------ // Build the header for the 1st sub-part, which will contain the SOAP envelope. // It will look like this: // Content-Type: application/xop+xml; charset=UTF-8; type="text/xml" // Content-Transfer-Encoding: 8bit // Content-ID: <rootpart@soapui.org> rest.put_PartSelector(L"1"); rest.AddHeader(L"Content-Type",L"application/xop+xml; charset=UTF-8; type=\"text/xml\""); rest.AddHeader(L"Content-Transfer-Encoding",L"8bit"); rest.AddHeader(L"Content-ID",L"<rootpart@soapui.org>"); soapXml.put_EmitCompact(true); soapXml.put_EmitXmlDecl(false); rest.SetMultipartBodyString(soapXml.getXml()); // ------------------------------------------------------------ // Build the header for the 1st sub-part, which will contain the SOAP envelope. // It will look like this: // Content-Type: application/octet-binary; name=A26MiFIR_Testfile_001.xml // Content-Transfer-Encoding: binary // Content-ID: <139580394822> // Content-Disposition: attachment; name=" A26MiFIR_Testfile_001.xml"; filename="A26MiFIR_Testfile_001.xml" rest.put_PartSelector(L"2"); rest.AddHeader(L"Content-Type",L"application/octet-binary; name=A26MiFIR_Testfile_001.xml"); rest.AddHeader(L"Content-Transfer-Encoding",L"binary"); rest.AddHeader(L"Content-ID",L"<139580394822>"); rest.AddHeader(L"Content-Disposition",L"attachment; name=\"A26MiFIR_Testfile_001.xml\"; filename=\"A26MiFIR_Testfile_001.xml\""); // We'll just use a fake attachment XML body for this example rest.SetMultipartBodyString(L"<test>blah blah blah</test>"); // ------------------------------------------------------------ // The request is fully specified. Now send the POST... // Turn on DebugMode. This is a mode where no request is sent. Instead, the request that would've been // sent is recorded and can be retrieved via the GetLastDebugRequest method. rest.put_DebugMode(true); const wchar_t *responseBody = rest.fullRequestMultipart(L"POST",L"/services/ws/t_a26mifir"); if (rest.get_LastMethodSuccess() != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } // Because we set DebugMode, no request was actually sent. Instead, we can examine the exact // request that would've been sent: if (rest.get_DebugMode() == true) { CkBinDataW bdRequest; success = rest.GetLastDebugRequest(bdRequest); success = bdRequest.WriteFile(L"qa_output/bafin_request.txt"); } wprintf(L"Success.\n"); // Clear the REST object for any subsequent requests.. rest.ClearAllHeaders(); rest.ClearAllParts(); rest.put_PartSelector(L""); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.