インデックス ページで、javascript SDK を初期化し、ログイン/認証フローを実行します。次に、AJAX を使用して、署名済みのリクエストを php ページに渡して解析します。署名されたリクエストを解析するためのコードは、ドキュメントから直接コピーされます。何も変更していません。そのコードの最後で、署名されたリクエストと同じオブジェクトで返されるユーザー情報を取得しようとしますが、AJAX 成功コールバックでこれらの変数のいずれかをログに記録しようとすると、「未定義」になります。
//HTML
function onCheckLoginStatus (response)
{
if (response.status != "connected")
{
//redirect to login page;
}
else
{
//CONNECTED, Get signed request from response object and pass it to PHP page via AJAX
$.ajax({
url : "http://XXXXXXX/bn/signedRequest.php",
type : 'POST',
data: {signed_request: response.authResponse.signedRequest},
success : function (result) {
console.log("success");
//THIS IS COMING UP UNDEFINED
console.log(result.uID);
},
error : function () {
alert("error");
}
});
//PHP
<?php
define('FACEBOOK_APP_ID', '27XXXXXX0&'); // Place your App Id here
define('FACEBOOK_SECRET', '8ea907XXXXXXX9e958'); // Place your App Secret Here
//GET THE SIGNED REQUEST
$signed_request = $_REQUEST['signed_request'];
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, '-_', '+/'));
}
if ($_REQUEST)
{
$response = parse_signed_request($_REQUEST['signed_request'],
FACEBOOK_SECRET);
}
$uID = $response["user_id"];
$name = $response["registration"]["name"];
$city = $response["registration"]["location"]["name"];
echo json_encode($uID);
?>