3

私はキャンバス アプリ (http://apps.facebook.com/myapp) を持っており、他のページ (ビジネスなど) はそれを自分のページに追加できます。アプリ内で、どのページから呼び出されているかを知るにはどうすればよいですか?

私はPHP-SDKを使用しています

4

1 に答える 1

8

Facebook Page Tab Tutorialに記載されているとおり:

ユーザーが Facebook ページに移動すると、ページ タブが次に使用可能なタブ位置に追加されていることがわかります。一般に、ページ タブはキャンバス ページとまったく同じ方法でロードされます。ユーザーがページ タブを選択する signed_requestと、1 つの追加パラメーターを含むパラメーターを受け取りますpage。このパラメーターには、id (現在のページのページ ID)、admin (ユーザーがページの管理者である場合)、および like (ユーザーがページを気に入った場合) を持つ JSON オブジェクトが含まれます。キャンバス ページと同様に、ユーザーがアプリを承認するまで、signed_request でアプリにアクセスできるすべてのユーザー情報を受け取ることはありません。

したがって、ページ ID をキャプチャする 1 つの方法は次のようになります。

<?php
// PATH TO FB-PHP-SDK
require '../../src/facebook.php';

$facebook = new Facebook(array(
  'appId'  => 'APP_ID',
  'secret' => 'APP_SECRET',
  'cookie' => true,
));
$signed_request = $facebook->getSignedRequest();
if( $page = $signed_request['page'] ) {
    echo $page['id'];
}
?>

または、PHP-SDK を使用しないソリューション:

<?php
if(!empty($_REQUEST["signed_request"])) {
    $app_secret = "APP_SECRET";
    $data = parse_signed_request($_REQUEST["signed_request"], $app_secret);

    if (isset($data["page"])) {
        echo $data["page"]["id"];
    } else {
        echo "Not in a page";
    }
}

function parse_signed_request($signed_request, $secret) {
    list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

    // decode the data
    $sig = base64_url_decode($encoded_sig);
    $data = json_decode(base64_url_decode($payload), true);

    if (strtoupper($data['algorithm']) !== 'HMAC-SHA256') {
        error_log('Unknown algorithm. Expected HMAC-SHA256');
        return null;
    }

    // check sig
    $expected_sig = hash_hmac('sha256', $payload, $secret, $raw = true);
    if ($sig !== $expected_sig) {
        error_log('Bad Signed JSON signature!');
        return null;
    }

    return $data;
}

function base64_url_decode($input) {
    return base64_decode(strtr($input, '-_', '+/'));
}
于 2011-04-08T08:31:24.533 に答える