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
(C++) Box.com Streaming Upload FileDemonstrates how to upload a file to box.com, streaming the file directly from the filesystem. Note: This example requires a fix that is included in Chilkat v9.5.0.70 and above.
#include <CkRest.h> #include <CkOAuth2.h> #include <CkJsonObject.h> #include <CkStream.h> void ChilkatSample(void) { // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkRest rest; bool success; // Provide a previously obtained OAuth2 access token. CkOAuth2 oauth2; oauth2.put_AccessToken("BOX_ACCESS_TOKEN"); rest.SetAuthOAuth2(oauth2); // First, make the initial connection. // A single REST object, once connected, can be used for many Box REST API calls. // The auto-reconnect indicates that if the already-established HTTPS connection is closed, // then it will be automatically re-established as needed. bool bAutoReconnect = true; // ---------------------------------------------------------------------- // IMPORTANT: Note that the domain is "upload.box.com", not "api.box.com" // ---------------------------------------------------------------------- success = rest.Connect("upload.box.com",443,true,bAutoReconnect); if (success != true) { std::cout << rest.lastErrorText() << "\r\n"; return; } // The request body uses the "multipart/form-data" format to transmit two "parts". // The first part is called "attributes" and contains a JSON object with information about the file, including the name of the file // and the ID of the parent folder. The second part contains the contents of the file. // (Note that the name of the second "part" is ignored.) rest.AddHeader("Content-Type","multipart/form-data"); // Provide the content for each part of the request... // First the JSON attributes. Use "0" for the root folder. // {"name":"hedgehogs.jpg", "parent":{"id":"0"}} CkJsonObject jsonAttr; jsonAttr.UpdateString("name","hedgehogs.jpg"); jsonAttr.UpdateString("parent.id","0"); rest.put_PartSelector("1"); rest.AddHeader("Content-Disposition","form-data; name=\"attributes\"; "); rest.SetMultipartBodyString(jsonAttr.emit()); // The upload will stream directly from a file. rest.put_PartSelector("2"); rest.AddHeader("Content-Disposition","form-data; name=\"file\"; filename=\"hedgehogs.jpg\""); // "application/octet-stream" can be safely used for any type file.. rest.AddHeader("Content-Type","application/octet-stream"); // IMPORTANT: This example requires Chilkat v9.5.0.70 or later, for a fix that was made in // multipart/streaming uploads. CkStream fileStream; fileStream.put_SourceFile("qa_data/jpg/hedgehogs.jpg"); rest.SetMultipartBodyStream(fileStream); // Restore the PartSelector to "0" (for safety, in case something else sends another request on this object) rest.put_PartSelector("0"); // Send the multipart/form-data request, which uploads the file by streaming directly from the filesystem. const char *responseBody = rest.fullRequestMultipart("POST","/api/2.0/files/content"); if (rest.get_LastMethodSuccess() != true) { std::cout << rest.lastErrorText() << "\r\n"; return; } // A 201 is received for a successful upload if (rest.get_ResponseStatusCode() != 201) { std::cout << "Box.com upload failed." << "\r\n"; std::cout << "Request header:" << "\r\n"; std::cout << rest.lastRequestHeader() << "\r\n"; std::cout << "---" << "\r\n"; std::cout << "Response status code = " << rest.get_ResponseStatusCode() << "\r\n"; std::cout << "Response body:" << "\r\n"; std::cout << responseBody << "\r\n"; return; } std::cout << "File uploaded." << "\r\n"; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.