PHP ActiveX
PHP ActiveX
Create a File in a Folder
See more Google Drive Examples
Creates (uploads) a file to be located in a particular folder.See Google Drive Files: create for more details.
Also See Google Drive Multipart Upload for more details.
Chilkat PHP ActiveX Downloads
<?php
$success = 0;
$success = 1;
// This example 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.
$bAutoReconnect = 1;
$success = $rest->Connect('www.googleapis.com',443,1,$bAutoReconnect);
// Provide the authentication credentials (i.e. the access token)
$rest->SetAuthGoogle($gAuth);
// -------------------------------------------------------------------------
// A multipart upload to Google Drive needs a multipart/related Content-Type
$rest->AddHeader('Content-Type','multipart/related');
// Specify each part of the request.
// The 1st part is JSON with information about the file.
$rest->PartSelector = '1';
$rest->AddHeader('Content-Type','application/json; charset=UTF-8');
$json = new COM("Chilkat.JsonObject");
$json->AppendString('name','testHello.txt');
$json->AppendString('description','A simple file that says Hello World.');
$json->AppendString('mimeType','text/plain');
// To place the file in a folder, we must add a parents[] array to the JSON
// and list the folder id's. It's possible for a file to be in multiple folders at once
// if it has more than one parent. If no parents are specified, then the file is created
// in the My Drive folder.
// Note: We'll assume we already have the id if the folder. It is the id's that are specified here,
// not the folder names.
$parents = new COM("Chilkat.JsonArray");
$json->AppendArray2('parents',$parents);
$folderId = '0B53Q6OSTWYolY2tPU1BnYW02T2c';
$parents->AddStringAt(-1,$folderId);
$rest->SetMultipartBodyString($json->emit());
// The 2nd part is the file content, which will contain "Hello World!"
$rest->PartSelector = '2';
$rest->AddHeader('Content-Type','text/plain');
$fileContents = 'Hello World!';
$rest->SetMultipartBodyString($fileContents);
$jsonResponse = $rest->fullRequestMultipart('POST','/upload/drive/v3/files?uploadType=multipart');
if ($rest->LastMethodSuccess == 0) {
print $rest->LastErrorText . "\n";
exit;
}
// A successful response will have a status code equal to 200.
if ($rest->ResponseStatusCode != 200) {
print 'response status code = ' . $rest->ResponseStatusCode . "\n";
print 'response status text = ' . $rest->ResponseStatusText . "\n";
print 'response header: ' . $rest->ResponseHeader . "\n";
print 'response JSON: ' . $jsonResponse . "\n";
exit;
}
// Show the JSON response.
$json->Load($jsonResponse);
// Show the full JSON response.
$json->EmitCompact = 0;
print $json->emit() . "\n";
// A successful response looks like this:
// {
// "kind": "drive#file",
// "id": "0B53Q6OSTWYoldmJ0Z3ZqT2x5MFk",
// "name": "Untitled",
// "mimeType": "text/plain"
// }
// Get the fileId:
print 'fileId: ' . $json->stringOf('id') . "\n";
?>