Sharing count on Facebook, Twitter, and LinkedIn

  最近一段時間一直在研究有關Social Network的東西,這裏有幾個在當前國外主流社交網站上用來顯示分享數量的API,記錄一下,從此可能會用得着。html

Facebookajax

  Facebook將FQL(Facebook Query Language)查詢語句以URL參數的形式傳遞給服務器來實現查詢,不只能夠查詢當前頁面的Sharing count,還能夠查詢許多數據。所涉及到的表和相關字段能夠參考Facebook的官方文檔:https://developers.facebook.com/docs/reference/fql/json

  這裏還有一個Facebook sharing counter的查詢工具,直接輸入要查詢的頁面的URL地址就能夠查詢該頁面在Facebook中被分享過多少次了http://www.emetello.com/facebook-share-counter/
api

  下面是一段經過JavaScript代碼在頁面上顯示分享到Facebook的次數,代碼經過JQuery的Ajax方法調用Facebook的查詢語句來獲取分享次數的數字。注意觀察Ajax中的url參數,其中query的值是一個FQL查詢語句,當前查詢link_stat表的share_count字段。Facebook的FQL查詢語句不支持*通配符來查詢表的全部字段。format參數用來指定返回值的類型,本例中爲json對象字符串。timestamp參數是人爲添加的,做用是爲了避開可能的瀏覽器緩存。displaySharingCount方法負責在頁面上顯示獲取到的結果,若是數字大於三位數,則只顯示"500+",並給元素添加title屬性用以顯示完整的值;不然就直接顯示值。瀏覽器

function displaySharingCount(val, objId) {
    var blank = " ";
    var id = "#" + objId
    if (typeof (val) != "undefined") {
        if (val.length > 3) {
            $(id).attr("title", val);
            $(id).text(blank + "500+");
        }
        else
            $(id).text(blank + val);
    }
}

window.onload = function () {
    var currUrl = encodeURIComponent(location.href);

    $.ajax({
        url: "https://api.facebook.com/method/fql.query?query=select%20share_count%20from%20link_stat%20where%20url=%22" + currUrl + "%22&format=json&timestamp=" + new Date().getTime(),
        type: "get",
        datatype: "html",
        async: true,
        success: function (data) {
            displaySharingCount(data[0].share_count, "Facebook_count");
        }
    });
 };

 

Twitter & LinkedIn緩存

  Twitter和LinkedIn在獲取sharing count方面很類似,都是經過一個URL來獲取返回結果,能夠指定返回結果是json格式或jsonp。看下面的例子,經過jsonp來獲取Twitter和LinkedIn的sharing count值。服務器

function getTwitterCount(obj) {
    displaySharingCount(obj.count, "Twitter_count");
}

function getLinkedInCount(obj) {
    displaySharingCount(obj.count, "LinkedIn_count");
}

function createScript(id, src) {
    var js, fjs = document.getElementsByTagName("script")[0];
    js = document.getElementById(id);
    if (js) {
        document.removeChild(js);
    }
    js = document.createElement("script");
    js.id = id;
    js.src = src;
    fjs.parentNode.insertBefore(js, fjs);
}

window.onload = function () {
    var currUrl = encodeURIComponent(location.href);

    createScript("Twitter_jscallback", "http://urls.api.twitter.com/1/urls/count.json?url=" + currUrl + "&format=jsonp&callback=getTwitterCount");
    createScript("LinkedIn_jscallback", "http://www.linkedin.com/countserv/count/share?url=" + currUrl + "&format=jsonp&callback=getLinkedInCount");
};

  LinkedIn的官方網站上有關於如何使用sharing count的介紹:https://developer.linkedin.com/retrieving-share-counts-custom-buttonsasync

  有一個地方須要注意,那就是當前頁面的URL字符串是大小寫敏感的,並且是否encoded也會有影響。例以下面這幾個URL,雖然指向的都是同一個頁面,可是獲取到的sharing count也會有區別:ide

http://www.cnblogs.com/jaxu工具

http://www.cnblogs.com/Jaxu

http%3A%2F%2Fwww.cnblogs.com%2Fjaxu

相關文章
相關標籤/搜索