0

我正在阅读有关创建 facebook 应用程序的 facebook 教程,

http://developers.facebook.com/docs/appsonfacebook/tutorial/

这是他们提供给我的代码。他们说在用户接受我的应用程序检索其信息的权限后立即运行它。

 <?php 

     $app_id = "YOUR_APP_ID";

     $canvas_page = "YOUR_CANVAS_PAGE_URL";

     $auth_url = "http://www.facebook.com/dialog/oauth?client_id=" 
            . $app_id . "&redirect_uri=" . urlencode($canvas_page);

     $signed_request = $_REQUEST["signed_request"];

     list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

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

     if (empty($data["user_id"])) {
            echo("<script> top.location.href='" . $auth_url . "'</script>");
     } else {
            echo ("Welcome User: " . $data["user_id"]);
     } 
 ?>

在教程中,他们说在用户接受您的应用程序后运行代码。这是我唯一一次能够获得用户 ID 吗???是否有必要拥有signed_request 或者我可以在他们已经接受我的应用程序权限后检索它

谢谢

4

1 回答 1

0

我如何解决它是这样的。Facebook 应用程序总是要求提供画布 URL(安全和非安全)。我创建了一个启动 url,当用户进入我的页面时,他们总是输入启动 url。这是我设置以下代码的地方。一旦我获得 user_id,我将其设置为会话并将它们重定向到应用程序的仪表板。在那里我可以检索用户 ID 并做我想做的事。

www.yourwebsite.com/initiate/

 $app_id = "YOUR_APP_ID";

 $canvas_page = "YOUR_CANVAS_PAGE_URL";

 $auth_url = "http://www.facebook.com/dialog/oauth?client_id=" 
        . $app_id . "&redirect_uri=" . urlencode($canvas_page);

 $signed_request = $_REQUEST["signed_request"];

 list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

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

 if (empty($data["user_id"])) {
        echo("<script> top.location.href='" . $auth_url . "'</script>");
 } else {
        $data["user_id"];//Set the data to a session or db then redirect user to the page
         //you want them to be
 } 
于 2012-12-21T23:11:30.427 回答