2

Webサイトを作成し、JavaScriptを使用して、Facebookページからフィードを読み取り、ログインしなくてもサイトの訪問者に表示したり、さらにはFacebookを使用したりすることは可能ですか。

Facebookのドキュメントで迷子になっています:(

4

2 に答える 2

2

@mchのおかげで、JavaScriptでFacebookフィードを読み取るためのプロキシとしてphpを使用するバージョンがここにあります。

サーバーにproxy.phpというファイルを配置し、次のコードを追加します。

<?php
// always add this header to ensure the JSON is output in the correct format
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Cache-Control: no-cache");
header("Pragma: no-cache");
header('Content-Type: application/json; charset=utf-8'); 

$graphUrl = $_POST[graphUrl];
if ($graphUrl == "") {
    $graphUrl = "https://graph.facebook.com/facebook/feed/";
}

//App Info, needed for Auth
$app_id = "1234567890";
$app_secret = "0000011122234334445556aaass";

//retrieve auth token
$authToken = fetchUrl("https://graph.facebook.com/oauth/access_token?type=client_cred&client_id={$app_id}&client_secret={$app_secret}");

//Echo back json to read client side.
echo fetchUrl("{$graphUrl}?{$authToken}");

function fetchUrl($url){
    $ch = curl_init();
    curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_TIMEOUT, 20);
    $retData = curl_exec($ch);
    curl_close($ch); 
    return $retData;
}
?>

app_id、app_secretをアプ​​リIDに変更します。ここでアプリを作成しますhttps://developers.facebook.com/apps/

プロキシファイルの横にHTMLファイルを作成します。このコードを追加します:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>FB reader</title>
</head>
<body>
    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function() {

            var timeout = 5000,
                load_error;

            load_error = function (jqXHR, textStatus, errorThrown) {
                if (errorThrown === "timeout") {
                    alert('Server bussy');
                } else {
                    alert('error: 404', textStatus + ": " + errorThrown);
                }
            };      

            $(document).ready(function() {
                console.log('Loading from Facebook...\n');

                //Change data: {graphUrl: 'https://graph.facebook.com/iambounty/feed'},  to what ever you want.
                $.ajax({
                    type: 'POST',
                    url: 'proxy.php',
                    data: {graphUrl: 'https://graph.facebook.com/iambounty/feed'}, 
                    timeout:  timeout,
                    error: load_error,
                    success: function (rv) {
                        var data = rv.data,
                            len = data.length,
                            i,
                            out = '';
                        for (i = 0; i < len; i += 1) {
                            if (data[i].description) {
                                out += data[i].description + '\n\n';
                            }
                        }
                        console.log(out);
                    }
                });

            });
        });
    </script>
</body>
</html>
于 2012-05-04T06:17:08.727 に答える
2

PHPを使用してサーバー側で実行できます。FacebookデベロッパーセンターでFacebookアプリを作成して、アプリキーとシークレットキーを取得します。

$profile_id = "1234567890";     

//App Info, needed for Auth
$app_id = "0001234567890";
$app_secret = "abc123ebf123f3g5g6j";

/* USE THIS LINE INSTEAD OF THE "veryfypeer" LINE BELOW */
Facebook::$CURL_OPTS[CURLOPT_CAINFO] = '/path/to/crt/fb_ca_chain_bundle.crt';

//retrieve auth token
$authToken = fetchUrl("https://graph.facebook.com/oauth/access_token?type=client_cred&client_id={$app_id}&client_secret={$app_secret}");

$data['feed_data'] = fetchUrl("https://graph.facebook.com/{$profile_id}/feed?{$authToken}");

function fetchUrl($url){
         $ch = curl_init();

/* DO NOT USE THE FOLLOWING LINE: I'VE COMMENTED IT OUT HERE */
//      curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
             curl_setopt($ch, CURLOPT_URL, $url);
             curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
             curl_setopt($ch, CURLOPT_TIMEOUT, 20);

         $retData = curl_exec($ch);
         curl_close($ch); 

         return $retData;
    }

... Javascript側では、FB APIシークレットを公開しないようにする必要があるため、それは不可能だと思います。ここから取られた情報

于 2012-05-03T09:10:57.640 に答える