Instagram异步Feed

时间:2015-10-26 13:03:28

标签: php asynchronous instagram feed

在这篇文章How to get a user's Instagram feed之后,我用它来显示最后一张图片



        function fetchData($url){
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 20);
        $result = curl_exec($ch);
        curl_close($ch); 
        return $result;
        }

        $result = fetchData("https://api.instagram.com/v1/users/123456789/media/recent/?access_token=123456789.123asdsd.asdadasdas23423423&count=1");
        $result = json_decode($result);
        foreach ($result->data as $post) {
        if(empty($post->caption->text)) {
        // Do Nothing
        }
        else {
        // Display img
        }
        }

如何异步加载?有时甚至需要2-3秒才能加载并延迟显示整个页面。 Tks for time time and help!

1 个答案:

答案 0 :(得分:1)

修改
转到@steve,我通过查询instagram api每小时解决一次并将响应保存到instagram.json

GET-社会忽略原始

function get_instagram($user_id=instagram_user_id,$count=1){

$instaurl = `https://api.instagram.com/v1/users/`.$user_id.`/media/recent/?access_token=instagram_access_token&count=`.$count;

$instacache = `instagram.json`;
$ch = curl_init();
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_URL,$instaurl);
$instadata=curl_exec($ch);
curl_close($ch);

if(file_exists($instacache) && filemtime($instacache) > time() - 60*30){
    //echo "ok instagram";
} else {
    $jsonInstaData = json_decode($instadata,true);
    file_put_contents($instacache,json_encode($jsonInstaData));
}
}
echo get_instagram();


和前端社交媒体-bat.phtml(magento& bootstrap)的ajax

jQuery(document).ready(function($) {  
$("#instagram-img").html("");
$.ajax({  
    type: "GET",  
    async: true,  
    contentType: "application/json; charset=utf-8",  
    url:"resources/socialmedia-cache/instagram.json",  
    dataType: "json",  
    cache: true,  
    beforeSend: function () {  
        $("#loading").show();  
    },  
    success: function (data) {  
        console.log(data);  
        $("#loading").hide();  
        if (data == "") {  
            $("#InstaContainer").hide();  
        } else {  
            $("#InstaContainer").show();  

            for (var i = 0; i < data["data"].length; i++) {  
                var dataForJson = JSON.stringify(data.data[i]);  
                var date = new Date(parseInt(data.data[i].caption.created_time) * 1000);  
                $("#instagram-img").append("<a target=`_blank` href=`" + data.data[i].link + "` title=`" + data.data[i].caption.text + "`><img src=`" + data.data[i].images.low_resolution.url + "` class=`img-responsive socialmedia-img`></img></a>");  
                $("#instagram-img").append("<p align=`left`><script>" + "jQuery(document).ready(function() { jQuery(`a.timeago`).timeago();});" + "</" + "script><a class=`timeago` style=`color:#484848;` title=`" +(date.getMonth()+1)+"/"+date.getDate()+"/"+date.getFullYear()+", "+date.getHours()+":"+date.getMinutes()+ "`>" +(date.getMonth()+1)+"/"+date.getDate()+"/"+date.getFullYear()+", "+date.getHours()+":"+date.getMinutes()+ "</a></p>");  
            }  
        }  
    }  
});  
}); 

这也适用于facebook
对于pinterest,我使用http://ajax.googleapis.com/ajax/services/feed/load?v=1.0&num=1&q=https://www.pinterest.com/MyPinterest/feed.rss,一个将rss转换为json的快速解决方案。因为我需要大于236px的图像,接下来解析的是736px。另外,img src需要从内容中提取

var string = data.responseData.feed.entries[i].content;
var filtered = string.replace('/236x/', '/736x/');
var source = filtered.match(/src\s*=\s*"(.+?)"/);

可能不是最好的代码,但至少是一个可行的解决方案。