|  | 
Chilkat  HOME  Android™  AutoIt  C  C#  C++  Chilkat2-Python  CkPython  Classic ASP  DataFlex  Delphi DLL  Go  Java  Node.js  Objective-C  PHP Extension  Perl  PowerBuilder  PowerShell  PureBasic  Ruby  SQL Server  Swift  Tcl  Unicode C  Unicode C++  VB.NET  VBScript  Visual Basic 6.0  Visual FoxPro  Xojo Plugin
| (Perl) Search for Files in Google DriveThis example follows the same methodology for listing all files in Google Drive in pages, but applies a search filter. It shows how to apply a query parameter for filtering the file results. See the Google Drive Files list for more optional HTTP parameters. 
 use chilkat(); $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 = chilkat::CkAuthGoogle->new(); $gAuth->put_AccessToken("GOOGLE-DRIVE-ACCESS-TOKEN"); $rest = chilkat::CkRest->new(); # 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); # Get 5 results per page for testing. (The default page size is 100, with a max of 1000. $rest->AddQueryParam("pageSize","5"); # Our search filter is to list all files containing ".jpg" (i.e. all JPG image files) $rest->AddQueryParam("q","name contains '.jpg'"); $json = chilkat::CkJsonObject->new(); # Send the request for the 1st page. $jsonResponse = $rest->fullRequestNoBody("GET","/drive/v3/files"); $pageNumber = 1; $bContinueLoop = $rest->get_LastMethodSuccess() and ($rest->get_ResponseStatusCode() == 200); while ($bContinueLoop == 1) { print "---- Page " . $pageNumber . " ----" . "\r\n"; # Iterate over each file in the response and show the name, id, and mimeType. $json->Load($jsonResponse); $numFiles = $json->SizeOfArray("files"); $i = 0; while ($i < $numFiles) { $json->put_I($i); print "name: " . $json->stringOf("files[i].name") . "\r\n"; print "id: " . $json->stringOf("files[i].id") . "\r\n"; print "mimeType: " . $json->stringOf("files[i].mimeType") . "\r\n"; print "-" . "\r\n"; $i = $i + 1; } # Get the next page of files. # If the "nextPageToken" is present in the JSON response, then use it in the "pageToken" parameter # for the next request. If no "nextPageToken" was present, then this was the last page of files. $pageToken = $json->stringOf("nextPageToken"); $bContinueLoop = 0; $bHasMorePages = $json->get_LastMethodSuccess(); if ($bHasMorePages == 1) { $rest->ClearAllQueryParams(); $rest->AddQueryParam("pageSize","5"); $rest->AddQueryParam("pageToken",$pageToken); $rest->AddQueryParam("q","name contains '.jpg'"); $jsonResponse = $rest->fullRequestNoBody("GET","/drive/v3/files"); $bContinueLoop = $rest->get_LastMethodSuccess() and ($rest->get_ResponseStatusCode() == 200); $pageNumber = $pageNumber + 1; } } if ($rest->get_LastMethodSuccess() != 1) { print $rest->lastErrorText() . "\r\n"; exit; } # A successful response will have a status code equal to 200. if ($rest->get_ResponseStatusCode() != 200) { print "response status code = " . $rest->get_ResponseStatusCode() . "\r\n"; print "response status text = " . $rest->responseStatusText() . "\r\n"; print "response header: " . $rest->responseHeader() . "\r\n"; print "response JSON: " . $jsonResponse . "\r\n"; exit; } | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.