有没有办法检查Facebook访问令牌是否仍然有效?

时间:2010-10-02 09:35:57

标签: facebook facebook-graph-api facebook-rest-api

我的网站使用终身访问令牌(offline_access)。但是,如果用户更改了他/她的密码,则会重置访问令牌。是否有方法在调用Graph API之前检查当前访问令牌是否有效?谢谢你的时间。

10 个答案:

答案 0 :(得分:69)

离线,没有向Facebook发送任何内容 - 我不这么认为。最简单的方法可能是发送请求:

https://graph.facebook.com/me?access_token=...

Facebook还支持订阅real-time更新,但我不确定如何将它们应用于这种情况。

答案 1 :(得分:43)

如果您想知道令牌到期时间,您可以使用appid和令牌传递打开的图表网址,如下所示。

https://graph.facebook.com/oauth/access_token_info?client_id=APPID&access_token=xxxxxxxxx

答案 2 :(得分:37)

基本上,FB要求您进行轮询,或者检测案例并重定向用户以获得真相。烦人,但官方:

(旧的,过时的链接。见下文) https://developers.facebook.com/blog/post/500/

编辑:Facebook改变了他们的链接结构,没有重定向。并不感到惊讶。

https://developers.facebook.com/blog/post/2011/05/13/how-to--handle-expired-access-tokens/

答案 3 :(得分:7)

答案 4 :(得分:4)

实时更新将允许您解决此问题,但这将非常复杂。基本上,您可以订阅更新,告诉您1)用户是否删除了应用程序,或者2)用户是否删除了权限。您可以使用它来存储faceboook用户的当前权限。这样,如果用户删除了您的应用,您就会知道访问令牌已过期。

实时更新实际上是facebook推荐的处理权限的方式。每次加载页面时,许多应用程序都会进行api调用以检查权限。这往往是缓慢和不可靠的。

答案 5 :(得分:1)

        //When user access token expires user must be logged in and renew the access token him self.it is a Facebook policy 
        //you can overcome this by sending email to users who have expired access token.
        //create a table of successful sending to monitor sending process
        //if any failure happened with the user an email is sent to him to ask him to activate there account again.with a link to your subscription page.
        //and here is the code should be written on that page. 
         $app_id = "YOUR_APP_ID";
         $app_secret = "YOUR_APP_SECRET"; 
         $my_url = "YOUR_POST_LOGIN_URL";

        // known valid access token stored in a database 
        $access_token = "YOUR_STORED_ACCESS_TOKEN";

        $code = $_REQUEST["code"];

       // If we get a code, it means that we have re-authed the user 
       //and can get a valid access_token. 
       if (isset($code)) {
         $token_url="https://graph.facebook.com/oauth/access_token?client_id="
           . $app_id . "&redirect_uri=" . urlencode($my_url) 
           . "&client_secret=" . $app_secret 
           . "&code=" . $code . "&display=popup";
         $response = file_get_contents($token_url);
         $params = null;
         parse_str($response, $params);
         $access_token = $params['access_token'];
       }


       // Attempt to query the graph:
       $graph_url = "https://graph.facebook.com/me?"
         . "access_token=" . $access_token;
       $response = curl_get_file_contents($graph_url);
       $decoded_response = json_decode($response);

       //Check for errors 
       if ($decoded_response->error) {
       // check to see if this is an oAuth error:
         if ($decoded_response->error->type== "OAuthException") {
           // Retrieving a valid access token. 
           $dialog_url= "https://www.facebook.com/dialog/oauth?"
             . "client_id=" . $app_id 
             . "&redirect_uri=" . urlencode($my_url);
           echo("<script> top.location.href='" . $dialog_url 
          . "'</script>");
        }
        else {
          echo "other error has happened";
        }
      } 
      else {
      // success
        echo("success" . $decoded_response->name);
        echo($access_token);
      }

      // note this wrapper function exists in order to circumvent PHP's 
      //strict obeying of HTTP error codes.  In this case, Facebook 
      //returns error code 400 which PHP obeys and wipes out 
      //the response.
      function curl_get_file_contents($URL) {
        $c = curl_init();
        curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($c, CURLOPT_URL, $URL);
        $contents = curl_exec($c);
        $err  = curl_getinfo($c,CURLINFO_HTTP_CODE);
        curl_close($c);
        if ($contents) return $contents;
        else return FALSE;
      }

答案 6 :(得分:1)

离线 - 不可能

询问用户是否已授予权限:

https://graph.facebook.com/{facebook-id}/permissions?access_token={access-token}

如果访问令牌无效,则会出错:

{  
   error:{  
      message:"The access token could not be decrypted",
      type:"OAuthException",
      code:190
   }
}

否则,它将给出用户提供的权限列表:

data:[  
   {  
      installed:1,
      ...... permission list......... 
      bookmarked:1
   }
]

答案 7 :(得分:1)

我经历了这些帖子,我找到了非常好的解决方案:

GET graph.facebook.com/debug_token?
    input_token={token-to-inspect}
    &access_token={app_id}|{app_secret}

此请求的回复为您提供了所需的一切:

  • 您的应用ID - 这会验证该令牌是否来自您的应用
  • 应用程序名称 - 也可以检查
  • expires_at - 令牌过期时间
  • is_valid - 用于检查的布尔值
  • user_id - 您还可以对其进行比较和检查

请注意&#34; |&#34;标志必须在那里作为信件

答案 8 :(得分:0)

自OP以来事情发生了变化,对此进行了更新:

您可以在此处调试访问令牌:https://developers.facebook.com/tools/debug/accesstoken?version=v2.5&q= {access_token}

答案 9 :(得分:-6)

Otto对facebook帖子的回答似乎是关于这个问题的官方回复,但是它使用直接PHP而不是SDK,并且还使用JS来解决问题而不是PHP。如果您使用PHP检查有效会话,则通常需要一种确保有效会话的PHP方法才能继续。

以下代码使用图API检查me对象。如果抛出异常,则会破坏当前的Facebook会话。

try{
    $facebook->api('/me');
}
catch( FacebookApiException $e ){
    $facebook->destroySession();
}

这迫使后来的图形调用实例化一个新的Facebook会话。这至少可以让您访问公共数据,以便您可以呈现页面不需要FB用户权限:

$facebook->api('/userName');

要重新获得用户权限访问权限,用户需要登录您的应用程序(这与登录Facebook本身不同)。您可以使用JS或PHP执行此操作:

$facebook->getLoginUrl();

*请注意,destroySession()调用尚未在PHP SDK的标记版本中。使用master分支或将其修补。