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
(Swift 2) Box.com Upload FileSee more Box ExamplesDemonstrates how to upload a file to box.com.
func chilkatTest() { // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // ------------------------------------------------------------------------------------------ // Important: // See this information about Box.com Service Accounts // Box.com will automatically generate a Service Account where the name of the account is the name of your App. // When you make API calls, it is for this service account, and the files that exist and what you see are not the same as your normal account. // ------------------------------------------------------------------------------------------ let rest = CkoRest() var success: Bool // Provide a previously obtained OAuth2 access token. let oauth2 = CkoOAuth2() oauth2.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. var bAutoReconnect: Bool = true // ---------------------------------------------------------------------- // IMPORTANT: Note that the domain is "upload.box.com", not "api.box.com" // ---------------------------------------------------------------------- success = rest.Connect("upload.box.com", port: 443, tls: true, autoReconnect: bAutoReconnect) if success != true { print("\(rest.LastErrorText)") 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", value: "multipart/form-data") // Provide the content for each part of the request... // First the JSON attributes. Use "0" for the root folder. // {"name":"penguins.jpg", "parent":{"id":"0"}} let jsonAttr = CkoJsonObject() jsonAttr.UpdateString("name", value: "penguins.jpg") jsonAttr.UpdateString("parent.id", value: "0") rest.PartSelector = "1" rest.AddHeader("Content-Disposition", value: "form-data; name=\"attributes\"; ") rest.SetMultipartBodyString(jsonAttr.Emit()) rest.PartSelector = "2" rest.AddHeader("Content-Disposition", value: "form-data; name=\"file\"; filename=\"penguins.jpg\"") // "application/octet-stream" can be safely used for any type file.. rest.AddHeader("Content-Type", value: "application/octet-stream") // Load the file into a binary data object, and then upload.. let fileDataObj = CkoBinData() fileDataObj.LoadFile("qa_data/jpg/penguins.jpg") rest.SetMultipartBodyBd(fileDataObj) // Restore the PartSelector to "0" (for safety, in case something else sends another request on this object) rest.PartSelector = "0" // Send the multipart/form-data request, which uploads the file contained in fileDataObj var responseBody: String? = rest.FullRequestMultipart("POST", uriPath: "/api/2.0/files/content") if rest.LastMethodSuccess != true { print("\(rest.LastErrorText)") return } // A 201 is received for a successful upload if rest.ResponseStatusCode.intValue != 201 { print("Box.com upload failed.") print("Request header:") print("\(rest.LastRequestHeader)") print("---") print("Response status code = \(rest.ResponseStatusCode.intValue)") print("Response body:") print("\(responseBody!)") return } print("File uploaded.") } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.