Sample code for 30+ languages & platforms
PHP Extension

Download File from Dropbox (Streaming)

See more Dropbox Examples

Downloads a file from Dropbox, streaming it directly to a file in the filesystem.

Chilkat PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

$success = false;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

// A Dropbox access token should have been previously obtained.
// Dropbox access tokens do not expire.
// See Dropbox Access Token.

$rest = new CkRest();

// Connect to Dropbox
$success = $rest->Connect('content.dropboxapi.com',443,true,true);
if ($success == false) {
    print $rest->lastErrorText() . "\n";
    exit;
}

// Add request headers.
$rest->AddHeader('Authorization','Bearer DROPBOX_ACCESS_TOKEN');

// The download "parameters" are contained in JSON passed in an HTTP request header.
// This is the JSON indicating the file to be downloaded:
// { 
//    "path": "/Homework/lit/hamlet.xml",
// }

$json = new CkJsonObject();
$json->AppendString('path','/Homework/lit/hamlet.xml');
$rest->AddHeader('Dropbox-API-Arg',$json->emit());

// Setup a file stream for the download
$fileStream = new CkStream();
$fileStream->put_SinkFile('qa_output/hamletFromDropbox.xml');

// Indicate that the call to FullRequestNoBody should send the response body
// to fileStream if the response status code is 200.
// If a non-success response status code is received, then nothing
// is streamed to the output file and the error response is returned by FullRequestNoBody.
$expectedStatus = 200;
$rest->SetResponseBodyStream($expectedStatus,true,$fileStream);

$responseStr = $rest->fullRequestNoBody('POST','/2/files/download');
if ($rest->get_LastMethodSuccess() == false) {
    print $rest->lastErrorText() . "\n";
    exit;
}

// When successful, Dropbox responds with a 200 response code.
if ($rest->get_ResponseStatusCode() != 200) {
    // Examine the request/response to see what happened.
    print 'response status code = ' . $rest->get_ResponseStatusCode() . "\n";
    print 'response status text = ' . $rest->responseStatusText() . "\n";
    print 'response header: ' . $rest->responseHeader() . "\n";
    print 'response body (if any): ' . $responseStr . "\n";
    print '---' . "\n";
    print 'LastRequestStartLine: ' . $rest->lastRequestStartLine() . "\n";
    print 'LastRequestHeader: ' . $rest->lastRequestHeader() . "\n";
    exit;
}

// Information about the downloaded file is also available as JSON in a response header.
// The "dropbox-api-result" response header contains the information.  For example:
$apiResult = $rest->responseHdrByName('dropbox-api-result');
print $apiResult . "\n";

// In this case, the pretty-formatted dropbox-api-result JSON looks like this:
// { 
//   "name": "hamlet.xml",
//   "path_lower": "/homework/lit/hamlet.xml",
//   "path_display": "/Homework/lit/hamlet.xml",
//   "id": "id:74FkdeNuyKAAAAAAAAAAAQ",
//   "client_modified": "2016-06-02T23:19:00Z",
//   "server_modified": "2016-06-02T23:19:00Z",
//   "rev": "9482db15f",
//   "size": 279658
// }

// Load the JSON, pretty-print it, and demonstrate how to get some values...
$jsonResult = new CkJsonObject();
$jsonResult->put_EmitCompact(false);
$jsonResult->Load($apiResult);
// Show the JSON pretty-printed...
print $jsonResult->emit() . "\n";

// Sample code to get data from the JSON response:
$size = $jsonResult->IntOf('size');
print 'size = ' . $size . "\n";

$rev = $jsonResult->stringOf('rev');
print 'rev = ' . $rev . "\n";

$clientModified = $jsonResult->stringOf('client_modified');
$ckdt = new CkDateTime();
$ckdt->SetFromTimestamp($clientModified);
$bLocalTime = true;
$dt = new CkDtObj();
$ckdt->ToDtObj($bLocalTime,$dt);

print $dt->get_Day() . '/' . $dt->get_Month() . '/' . $dt->get_Year() . ' ' . $dt->get_Hour() . ':'
     . $dt->get_Minute() . "\n";

?>