Sample code for 30+ languages & platforms
Objective-C

Box.com Upload File

See more Box Examples

Demonstrates how to upload a file to box.com.

Chilkat Objective-C Downloads

Objective-C
#import <CkoRest.h>
#import <CkoOAuth2.h>
#import <CkoJsonObject.h>
#import <CkoBinData.h>
#import <NSString.h>

BOOL success = NO;

// 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.
// ------------------------------------------------------------------------------------------

CkoRest *rest = [[CkoRest alloc] init];

//   Provide a previously obtained OAuth2 access token.
CkoOAuth2 *oauth2 = [[CkoOAuth2 alloc] init];
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.
BOOL bAutoReconnect = YES;

// ----------------------------------------------------------------------
// IMPORTANT: Note that the domain is "upload.box.com", not "api.box.com"
// ----------------------------------------------------------------------
success = [rest Connect: @"upload.box.com" port: [NSNumber numberWithInt: 443] tls: YES autoReconnect: bAutoReconnect];
if (success != YES) {
    NSLog(@"%@",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"}}
CkoJsonObject *jsonAttr = [[CkoJsonObject alloc] init];
[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..
CkoBinData *fileDataObj = [[CkoBinData alloc] init];
[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
NSString *responseBody = [rest FullRequestMultipart: @"POST" uriPath: @"/api/2.0/files/content"];
if (rest.LastMethodSuccess != YES) {
    NSLog(@"%@",rest.LastErrorText);
    return;
}

// A 201 is received for a successful upload
if ([rest.ResponseStatusCode intValue] != 201) {
    NSLog(@"%@",@"Box.com upload failed.");
    NSLog(@"%@",@"Request header:");
    NSLog(@"%@",rest.LastRequestHeader);
    NSLog(@"%@",@"---");
    NSLog(@"%@%d",@"Response status code = ",[rest.ResponseStatusCode intValue]);
    NSLog(@"%@",@"Response body:");
    NSLog(@"%@",responseBody);
    return;
}

NSLog(@"%@",@"File uploaded.");