1

我正在使用客户端 sdk 进行登录,并在服务器端 php sdk 中使用图形 api 对触发的操作进行“墙发布”(我将它与 offline_access 一起使用,但现在我知道它已被弃用)。

如何使用客户端 sdk 在服务器端获取扩展访问令牌,以便我可以在服务器端使用扩展令牌,

我知道这里有一些答案,但他们使用服务器端登录并从 $_REQUEST['code'] 获取扩展令牌,他们得到响应,

我有什么方法可以使用客户端登录获取 $_REQUEST['code'] 的值吗?

更新:

我的客户端登录代码支持 oAuth:

FB.init({
  appId      : 'MYAPPID', // App ID
  status     : true,  // check login status
  cookie     : true,  // enable cookies to allow the server to access  the session
  xfbml      : true,  // parse XFBML
  oauth      : true   // enable OAuth 2.0
});  

FB.login(function() {
   FB.api('/me', {'fields': "some coma seperated fields"},
      function(response){ 
        //Function that sends data to server
        Pass_data_to_server( response );
      });    
}, scope:'some scope values');

服务器端代码:

<?php
  $settings = array
  (
    'appId'  => FB_APP_ID,
    'secret' => FB_APP_SECRET,
    'cookie' => true,
    'oauth'  => true
  );    

  // Get facebook object from facebook sdk class
  $facebook  = new Facebook($settings); 

  if ($facebook)
  {                              
    $user_id   = $facebook->getUser();      

    $facebook->setExtendedAccessToken(); //long-live access_token 60 days
    $token     = $facebook->getAccessToken();            
    try 
    {                      
      $response = $facebook->api('me/og.like', 'POST',{ $MYCUSTOMDATA});
      return $response;
    }
    catch (FacebookApiException $e) 
    {
      print_r($e)
      return false;          
    }        
  }
?>
4

1 回答 1

1

您可以使用 Facebook PHP SDK 方法扩展您的访问令牌

setExtendedAccessToken()

这将通过调用端点自动扩展您的短期扩展访问令牌

https://graph.facebook.com/oauth/access_token?             
client_id=APP_ID&
client_secret=APP_SECRET&
grant_type=fb_exchange_token&
fb_exchange_token=EXISTING_ACCESS_TOKEN 

然后,您可以保存此访问令牌以授权接下来 60 天的请求。

于 2013-04-12T06:37:39.270 回答