I feel like I’m overthinking this. What I want to do is pull the most recent photos from the instagram api and save the resulting json information as a cache file. I’ll then use jQuery to read from that file — I’ve got that part figured out. What I’m using now is saving it in a cache file, but not in a format that I recognize. I think I’m overcomplicating this.
This is code I’ve been working with based on a tutorial I found:
// Client ID for Instagram API
$instagramClientID = '9110e8c268384cb79901a96e3a16f588';
$api = 'https://api.instagram.com/v1/media/popular?client_id='.$instagramClientID; //api request (edit this to reflect tags)
$cache = 'cache.txt';
if(file_exists($cache) && filemtime($cache) > time() - 60*60){
// If a cache file exists, and it is newer than 1 hour, use it
$images = unserialize(file_get_contents($cache));
}
else{
// Make an API request and create the cache file
// For example, gets the 32 most popular images on Instagram
$response = file_get_contents($api); //change request path to pull different photos
$images = array();
// Decode the response and build an array
foreach(json_decode($response)->data as $item){ // Decodes json (javascript) into an array
$title = '';
if($item->caption){
$title = mb_substr($item->caption->text,0,70,"utf8");
}
$src = $item->images->standard_resolution->url; //Caches standard res img path to variable $src
$lat = $item->data->location->latitude; // Caches latitude as $lat
$lon = $item->data->location->longtitude; // Caches longitude as $lon
$images[] = array(
"title" => htmlspecialchars($title),
"src" => htmlspecialchars($src),
"lat" => htmlspecialchars($lat),
"lon" => htmlspecialchars($lon) // Consolidates variables to an array
);
}
// Remove the last item, so we still have
// 32 items when when the cover is added
//array_pop($images);
// Push the cover in the beginning of the array
//array_unshift($images,array("title"=>"Cover", "src"=>"assets/img/cover.jpg"));
// Update the cache file
file_put_contents($cache,serialize($images));
}
One thing I noticed is the API is mega slow, good choice to cache.
You are attempting to save as a serialized array (which is no biggie) but you may as well save it as json if your going to read it as json again, it saves 1 step in unserializing it again.
Here are some changes I made:
Added curl to try and speed up the response or fall back to FGC if u dont have it installed.
The response gets saved as json, and when retrieved from the cache its decoded as an array instead of an object, this means you can keep your same array structure.
$item->data->location->latitudeand$item->data->location->longtitudeis always null in the result so added a check for that…Hope it helps