Java
Java
Paging User Photos with Cursor
See more Facebook Examples
Demonstrates how to iterate over the pages of user photos using a cursor.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// 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
CkOAuth2 oauth2 = new CkOAuth2();
oauth2.put_AccessToken("FACEBOOK-ACCESS-TOKEN");
CkRest rest = new CkRest();
// Connect to Facebook.
success = rest.Connect("graph.facebook.com",443,true,true);
if (success != true) {
System.out.println(rest.lastErrorText());
return;
}
// Provide the authentication credentials (i.e. the access key)
rest.SetAuthOAuth2(oauth2);
// Indicate that we only want the photos the user has personally uploaded.
rest.AddQueryParam("type","uploaded");
// We could limit the number of photos per page using the "limit" field.
rest.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.
String responseJson = rest.fullRequestNoBody("GET","/v2.7/me/photos");
if (rest.get_LastMethodSuccess() != true) {
System.out.println(rest.lastErrorText());
return;
}
CkJsonObject json = new CkJsonObject();
json.put_EmitCompact(false);
json.Load(responseJson);
System.out.println(json.emit());
//
// See Parsing the Facebook User Photos for code showing how to parse the JSON photos content.
//
// Get the "after" cursor.
String afterCursor = json.stringOf("paging.cursors.after");
while (json.get_LastMethodSuccess() == true) {
System.out.println("after cursor: " + afterCursor);
// 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.
rest.ClearAllQueryParams();
rest.AddQueryParam("type","uploaded");
rest.AddQueryParam("limit","20");
rest.AddQueryParam("after",afterCursor);
responseJson = rest.fullRequestNoBody("GET","/v2.7/me/photos");
if (rest.get_LastMethodSuccess() != true) {
System.out.println(rest.lastErrorText());
return;
}
json.Load(responseJson);
// See Parsing the Facebook User Photos for code showing how to parse the JSON photos content.
System.out.println(json.emit());
// Get the cursor for the next page.
afterCursor = json.stringOf("paging.cursors.after");
}
System.out.println("No more pages of photos.");
}
}