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
(Objective-C) Send SOAP multipart/related with XML Body and Zip AttachmentDemonstrates how to construct and send a multipart/related POST containing a SOAP XML body and a binary zip attachment.
#import <CkoRest.h> #import <CkoXml.h> #import <CkoBinData.h> #import <NSString.h> // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example constructs and sends the following HTTP request. // (The boundary strings will be different and auto-generated by Chilkat) // Accept-Encoding: gzip,deflate // SOAPAction: invio // Content-Type: Multipart/Related; boundary="MIME_boundary"; type="text/xml"; start="mailto:rootpart@soapui.org" // MIME-Version: 1.0 // // --MIME_boundary // Content-Type: text/xml; charset=UTF-8 // Content-Transfer-Encoding: 8bit // Content-ID: <rootpart@soapui.org> // // <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:urn="urn:attachment.ws.it"> // <soapenv:Header/> // <soapenv:Body> // <urn:inputBean> // <nomeFileAllegato>myfile.zip</nomeFileAllegato> // </urn:inputBean> // </soapenv:Body> // </soapenv:Envelope> // // --MIME_boundary // Content-Type: application/zip // Content-Transfer-Encoding: binary // Content-ID: <myfile.zip> // Content-Disposition: attachment; name="myfile.zip"; filename="myfile.zip" // // ... binary zip data goes here ... // --MIME_boundary-- // CkoRest *rest = [[CkoRest alloc] init]; BOOL success; [rest AddHeader: @"Accept-Encoding" value: @"gzip,deflate"]; [rest AddHeader: @"SOAPAction" value: @"invio"]; [rest AddHeader: @"Content-Type" value: @"Multipart/Related; boundary=\"MIME_boundary\"; type=\"text/xml\"; start=\"mailto:rootpart@soapui.org\""]; [rest AddHeader: @"MIME-Version" value: @"1.0"]; // Build the SOAP XML: // Use this online tool to generate the code from sample XML: // Generate Code to Create XML CkoXml *xml = [[CkoXml alloc] init]; xml.Tag = @"soapenv:Envelope"; [xml AddAttribute: @"xmlns:soapenv" value: @"http://schemas.xmlsoap.org/soap/envelope/"]; [xml AddAttribute: @"xmlns:urn" value: @"urn:attachment.ws.it"]; [xml UpdateChildContent: @"soapenv:Header" value: @""]; [xml UpdateChildContent: @"soapenv:Body|urn:inputBean|nomeFileAllegato" value: @"myfile.zip"]; // Build the SOAP XML sub-part rest.PartSelector = @"1"; [rest AddHeader: @"Content-Type" value: @"text/xml; charset=UTF-8"]; [rest AddHeader: @"Content-Transfer-Encoding" value: @"8bit"]; [rest AddHeader: @"Content-ID" value: @"<rootpart@soapui.org>"]; success = [rest SetMultipartBodyString: [xml GetXml]]; // Build the sub-part containing the .zip rest.PartSelector = @"2"; [rest AddHeader: @"Content-Type" value: @"application/zip"]; [rest AddHeader: @"Content-Transfer-Encoding" value: @"binary"]; [rest AddHeader: @"Content-ID" value: @"<myfile.zip>"]; [rest AddHeader: @"Content-Disposition" value: @"attachment; name=\"myfile.zip\"; filename=\"myfile.zip\""]; // Add a zip file to the 2nd sub-part body. // This example will load the .zip file into memory, but it is also possible to stream directly from the file as the request is sent // by calling SetMultipartBodyStream. CkoBinData *bd = [[CkoBinData alloc] init]; success = [bd LoadFile: @"qa_data/zips/helloWorld.zip"]; success = [rest SetMultipartBodyBd: bd]; // To be safe, always revert the PartSelector back to 0.. rest.PartSelector = @"0"; // Send the request by connecting to the web server and then sending.. // Connect using TLS. BOOL bAutoReconnect = YES; success = [rest Connect: @"www.chilkatsoft.com" port: [NSNumber numberWithInt: 443] tls: YES autoReconnect: bAutoReconnect]; if (success != YES) { NSLog(@"%@",rest.LastErrorText); return; } // In this example, we're setting DebugMode. // When debug mode is turned on, no request is actually sent. // Instead, the request that would be sent is recorded to memory // and we can retrieve it afterwards.. rest.DebugMode = YES; NSString *responseStr = [rest FullRequestMultipart: @"POST" uriPath: @"/someTargetPath"]; if (rest.LastMethodSuccess != YES) { NSLog(@"%@",rest.LastErrorText); return; } // Retrieve the request that would've been sent and save it to a file. // We can then examine the file to see if the request was structured as we desired. // (Note: The zip bytes will be binary data and will appear as garbled garbage in a text editor..) CkoBinData *bdRequest = [[CkoBinData alloc] init]; [rest GetLastDebugRequest: bdRequest]; success = [bdRequest WriteFile: @"qa_output/multipartRelatedRequest.bin"]; NSLog(@"%@",@"OK, examine the output file.."); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.