0

我想知道,这个静态 FBML 标记无论如何都可以在 IFrame 中工作:-

fb : 用户链接 uid="loggedinuser"

我的第二个问题是,我们能否通过存储的 Cokkies 获取用户 ID,而不是使用 FBML,因为 iframe facebook 不允许我们访问用户数据。所以使用 Firebug 我发现我们获取了用户 ID。并存储在 cookie 中。我希望用户被限制多次访问我的 iframe 。因此,通过获取用户 ID,我想检查用户是否已注册。如果他已经注册了。他不能注册两次。

我正在通过 Using Cokkies 尝试它,但由于缺乏关于 JAVASCRIPT 的知识,我没有得到如何执行它。

4

1 回答 1

0

将以下代码放入您的 iframe 中,您将获得登录的用户 ID,然后检查其约束。

<?php   

   function parse_signed_request($signed_request , $secret ) {
$signed_request = $signed_request ? $signed_request : $_REQUEST['signed_request'];
$secret = $secret ? $secret : your_app_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, '-_', '+/'));
}
  $request=$_REQUEST['signed_request']; 
  $appsecret = 'your_app_secret_key';
$new = parse_signed_request($request , $appsecret );
echo $new['user_id'];
于 2011-04-09T00:36:12.617 回答