Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) Paging User Photos with CursorDemonstrates how to iterate over the pages of user photos using a cursor.
LOCAL loOauth2 LOCAL loRest LOCAL lnSuccess LOCAL lcResponseJson LOCAL loJson LOCAL lcAfterCursor * This example requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * This example assumes a previously obtained an access token * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.OAuth2') loOauth2 = CreateObject('Chilkat.OAuth2') loOauth2.AccessToken = "FACEBOOK-ACCESS-TOKEN" * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Rest') loRest = CreateObject('Chilkat.Rest') * Connect to Facebook. lnSuccess = loRest.Connect("graph.facebook.com",443,1,1) IF (lnSuccess <> 1) THEN ? loRest.LastErrorText RELEASE loOauth2 RELEASE loRest CANCEL ENDIF * Provide the authentication credentials (i.e. the access key) loRest.SetAuthOAuth2(loOauth2) * Indicate that we only want the photos the user has personally uploaded. loRest.AddQueryParam("type","uploaded") * We could limit the number of photos per page using the "limit" field. loRest.AddQueryParam("limit","20") * Get the 1st page of photos. (Not the actual image data, but the information about each photo.) * See https://developers.facebook.com/docs/graph-api/reference/user/photos/ for more information. lcResponseJson = loRest.FullRequestNoBody("GET","/v2.7/me/photos") IF (loRest.LastMethodSuccess <> 1) THEN ? loRest.LastErrorText RELEASE loOauth2 RELEASE loRest CANCEL ENDIF * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJson = CreateObject('Chilkat.JsonObject') loJson.EmitCompact = 0 loJson.Load(lcResponseJson) ? loJson.Emit() * * See Parsing the Facebook User Photos for code showing how to parse the JSON photos content. * * Get the "after" cursor. lcAfterCursor = loJson.StringOf("paging.cursors.after") DO WHILE loJson.LastMethodSuccess = 1 ? "after cursor: " + lcAfterCursor * Prepare for getting the next page of photos. * We can continue using the same REST object. * If already connected, we'll continue using the existing connection. * Otherwise, a new connection will automatically be made if needed. loRest.ClearAllQueryParams() loRest.AddQueryParam("type","uploaded") loRest.AddQueryParam("limit","20") loRest.AddQueryParam("after",lcAfterCursor) lcResponseJson = loRest.FullRequestNoBody("GET","/v2.7/me/photos") IF (loRest.LastMethodSuccess <> 1) THEN ? loRest.LastErrorText RELEASE loOauth2 RELEASE loRest RELEASE loJson CANCEL ENDIF loJson.Load(lcResponseJson) * See Parsing the Facebook User Photos for code showing how to parse the JSON photos content. ? loJson.Emit() * Get the cursor for the next page. lcAfterCursor = loJson.StringOf("paging.cursors.after") ENDDO ? "No more pages of photos." RELEASE loOauth2 RELEASE loRest RELEASE loJson |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.