1

FOSFacebookBundle 的默认实现是使用客户端流。我已经尝试过了,它有效。现在我需要实现服务器端流程。然后我这样做:

点击时超链接将转到 Action 如下所示的路线:

$client_id = $this->container->getParameter('fos_facebook.app_id');
$redirect_uri = urlencode($this->generateUrl('_security_check', array(), true));
$scope = implode(',', $this->container->getParameter('fos_facebook.permissions'));
$state = md5(uniqid(rand(), TRUE)); //CSRF protection
$this->getRequest()->getSession()->set('facebook_state', $state);

$oauthUrl = 'https://www.facebook.com/dialog/oauth?client_id='.$client_id.'&redirect_uri='.$redirect_uri.'&scope='.$scope.'&state='.$state;
return $this->redirect($oauthUrl);

它被重定向到 Facebook,当用户单击允许然后重定向回我的应用程序时,该操作与处理客户端操作的操作相同

它返回错误:必须使用活动访问令牌来查询有关当前用户的信息

此错误是由以下行引起的:

$me = $this->fbapi->api('/me');

使用 facebook 服务器端流程的正确实现是什么?

4

1 回答 1

0

它被重定向到 Facebook,当用户单击允许然后重定向回我的应用程序时,该操作与处理客户端操作的操作相同

这是服务器端 Auth 流程的前三个步骤。

现在,您还必须执行第四步https ://developers.facebook.com/docs/authentication/server-side/

于 2012-09-24T07:45:31.767 回答