Sample code for 30+ languages & platforms
PHP ActiveX

Download Binary File to In-Memory Bytes

See more Google Drive Examples

This example demonstrates how to download the binary content of a file from Google Drive directly into local memory.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

$success = 1;

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

// This example uses a previously obtained access token having permission for the 
// Google Drive scope.

$gAuth = new COM("Chilkat.AuthGoogle");
$gAuth->AccessToken = 'GOOGLE-DRIVE-ACCESS-TOKEN';

$rest = new COM("Chilkat.Rest");

// Connect using TLS.
// A single REST object, once connected, can be used for many Google Drive 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.
$bAutoReconnect = 1;
$success = $rest->Connect('www.googleapis.com',443,1,$bAutoReconnect);

// Provide the authentication credentials (i.e. the access token)
$rest->SetAuthGoogle($gAuth);

// ------------------------------------------------------------------------------
// To download a file, we must know the file ID.
// In a previous example (see Build Local Metadata Cache
// we built a local cache to make it easy to lookup file IDs given a file path.
// Let's say we want to download "testFolder/abc/123/penguins.jpg".
// First we lookup the fileId in the cache.  With the fileId, we can download the file.
$gdCache = new COM("Chilkat.Cache");
$gdCache->Level = 0;
$gdCache->AddRoot('C:/ckCache/googleDrive');

$fileId = $gdCache->fetchText('testFolder/abc/123/penguins.jpg');
if ($gdCache->LastMethodSuccess != 1) {
    print 'Filepath not found in cache.' . "\n";
    exit;
}

// We need to send a GET request like this:
// GET https://www.googleapis.com/drive/v3/files/fileId?alt=media
// The fileId is part of the path.
$sbPath = new COM("Chilkat.StringBuilder");
$sbPath->Append('/drive/v3/files/');
$sbPath->Append($fileId);
$rest->AddQueryParam('alt','media');

// To download to memory, we'll send the request in one call, then receive
// the response header, and then the response body.
// If the response header indicates failure or an unexpected response, then the
// body is not the data we desire.

// First send the HTTP request.
$success = $rest->SendReqNoBody('GET',$sbPath->getAsString());
if ($success != 1) {
    print $rest->LastErrorText . "\n";
    exit;
}

// Get the response header.
$statusCode = $rest->ReadResponseHeader();
if ($statusCode != 200) {
    print 'response status code = ' . $rest->ResponseStatusCode . "\n";
    print 'response status text = ' . $rest->ResponseStatusText . "\n";
    print 'response header: ' . $rest->ResponseHeader . "\n";

    // Read the response body (which should be error text or HTML)
    $errResponseBody = $rest->readRespBodyString();
    if ($rest->LastMethodSuccess == 1) {
        print 'response body: ' . $errResponseBody . "\n";
    }

    exit;
}

// Read the response body, which should contain the file data.

$jpgBytes = $rest->ReadRespBodyBinary();
if ($rest->LastMethodSuccess != 1) {
    print $rest->LastErrorText . "\n";
    exit;
}

// Save jpgBytes to a file so we can examine the file to verify that it worked.
$fac = new COM("Chilkat.FileAccess");
$fac->WriteEntireFile('qa_output/penguins_out.jpg',$jpgBytes);

print 'File downloaded.' . "\n";

?>