1

我正在 Facebook 中编写一个应用程序,该应用程序旨在通过我自己的业务页面上的页面选项卡显示。我需要与查看用户进行交互,因此我需要扩展权限。

我已按照建议的程序进行操作,但现在碰壁了。我的应用程序位于 iFrame 中,并且对扩展权限的请求使用重定向。我可以获得您需要确认授权的页面,但是当您单击允许时,Facebook 会重定向到托管我的应用程序的页面,而不是返回到我的 Facebook 页面选项卡。一旦获得了适当的权限,应用程序的其余部分就可以正常工作,所以我知道这只是重定向的问题,但我觉得我已经尝试了所有方法,似乎没有很多人遇到同样的问题。如果有人能指出我正确的方向,我会很高兴。

谢谢!

这是我的代码:

$app_id = "myappid";

$canvas_page = "http://wheremyappishosted/";

$signed_request = $_REQUEST["signed_request"];
list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

$data = json_decode(base64_decode(strtr($payload, '-_', '+/')), true);

$user_id = $data["user_id"];
$access_token = $data['oauth_token'];

if (empty($data["user_id"])) {
 $auth_url = "https://graph.facebook.com/oauth/authorize?client_id=".$app_id."&redirect_uri=".urlencode($canvas_page)."&scope=user_photos,friends_photos,publish_stream,user_likes";
 die("<script> top.location.href='" . $auth_url . "'</script>");
}

$f = json_decode(file_get_contents("https://graph.facebook.com/".$user_id."?access_token=".$access_token."&fields=name,albums,likes"), true);
4

4 回答 4

4

对于那些感兴趣的人,我相信我已经找到了一种方法来规避这个问题。我没有将用户重定向回应用程序,而是将它们重定向到一个小脚本,然后重定向回页面选项卡。由于该应用程序已经获得授权,因此一切正常,并且 signed_request 与用户信息一起传递。我不知道这是否真的是合法的方式,但它确实有效。

于 2011-02-14T17:53:06.890 回答
0

将 redirect_uri 设置为“http[s]://apps.facebook.com/YOUR_APP/”而不是“http[s]://apps.facebook.com/YOUR_APP”。注意尾部的斜线!

于 2011-09-13T13:22:42.053 回答
0

我发现当使用服务器脚本出现未解决的重定向问题时,使用 javascript sdk 是更好的选择,实施这个小测试,你会发现大多数事情都是使用灯箱发生的,即在你的应用程序上方。这使应用程序页面保持完整。

https://developers.facebook.com/docs/facebook-login/getting-started-web/

于 2013-05-29T15:19:11.273 回答
0

请将重定向变量设置为您的目标页面:

$redirect = "http://foo.com";
于 2011-02-14T16:05:16.167 回答