如何通过 Facebook PHP SDK 传递多个范围参数来执行需要权限的查询



我有一个当前的 3 页网站/应用程序,可以使用我的 PHP SDK 代码从 Facebook 提取/显示数据,我收到错误:

redirect_uri URL 必须是绝对的

这是因为下面的代码:

$params = array(
       'scope' => 'ads_management',
       'redirect_uri' => 'http://example.com/login-callback.php',
    );
$loginUrl = $helper->getLoginUrl($params);

在将其更改为此之前,我根本没有这个^,只有这一行:

$loginUrl = $helper->getLoginUrl('http://example.com/login-callback.php');

如果我要查询不需要权限的帖子和东西,事情进展顺利。但是我需要执行如下所示的查询,位于fb-stats.php.我想我拥有参数的方式是错误的,但我并不完全知道格式化它的正确方法。

这是fb.php

<?php
    session_start();
    require_once '../vendor/autoload.php';
    // Checks if token is set and redirects to another page.
    if (isset($_SESSION['facebook_access_token'])) {
        // Logged in!
        header('Location: fb-stats.php'); exit();
    }
    $fb = new FacebookFacebook([
        'app_id' => 'MYAPPID',
        'app_secret' => 'MYAPPSECRET',
        'default_graph_version' => 'v2.5',
    ]);
    $helper = $fb->getRedirectLoginHelper();
    // The site below is 'example' is actually my live site.
    $params = array(
            'scope' => 'ads_management',
            'redirect_uri' => 'http://example.com/login-callback.php',
        );
    $loginUrl = $helper->getLoginUrl($params);
    echo '<a href="' . $loginUrl . '">Log in with Facebook!</a>';
?>

这是login-callback.php

<?php
    session_start();
    require_once '../vendor/autoload.php';
    $fb = new FacebookFacebook([
        'app_id' => 'MYAPPID',
        'app_secret' => 'MYAPPSECRET',
        'default_graph_version' => 'v2.5',
    ]);

    $helper = $fb->getRedirectLoginHelper();
    try {
        $accessToken = $helper->getAccessToken();
    }
    catch(FacebookExceptionsFacebookResponseException $e) {
        echo 'Graph returned an error: ' . $e->getMessage();
        exit;
    }
    catch(FacebookExceptionsFacebookSDKException $e) {
        echo 'Facebook SDK returned an error: ' . $e->getMessage();
        exit;
    }
    if (isset($accessToken)) {
        if (! $accessToken->isLongLived()) {
            try {
                $accessToken = $oAuth2Client->getLongLivedAccessToken($accessToken);
            }
            catch (FacebookExceptionsFacebookSDKException $e) {
                echo "<p>Error getting long-lived access token: " . $helper->getMessage() . "</p>nn";
                exit;
            }
        }
        header('Location: fb-stats.php'); exit();
    }

这是fb-stats.php

<?php
    session_start();
    require_once '../vendor/autoload.php';
    $fb = new FacebookFacebook([
        'app_id' => 'MYAPPID',
        'app_secret' => 'MYAPPSECRET',
        'default_graph_version' => 'v2.5',
    ]);
    $fb->setDefaultAccessToken('access-token');
    try {
        $response = $fb->get('/PAGEID/insights/page_impressions?period=day', '{access token}');
        $insightsNode = $response->getGraphEdge();
    }
    catch(FacebookExceptionsFacebookResponseException $e) {
        // When Graph returns an error
        echo 'Graph returned an error: ' . $e->getMessage();
        exit;
    }
    catch(FacebookExceptionsFacebookSDKException $e) {
        // When validation fails or other local issues
        echo 'Facebook SDK returned an error: ' . $e->getMessage();
        exit;
    }
    var_dump($insightsNode);

我尝试执行的查询需要 ads_managementread_insights 的权限,但我对如何让多个范围摆脱我目前因redirect_uri不是绝对而得到的错误感到困惑。我将如何解决这些问题?

$params = array(
       'scope' => 'ads_management',
       'redirect_uri' => 'http://example.com/login-callback.php',
    );
$loginUrl = $helper->getLoginUrl($params);

getLoginUrl 方法需要两个参数 - 但您在此处只向其传递一个数组。

使用此方法的正确方法是

$helper->getLoginUrl('http://example.com/login-callback.php', ['ads_management']);

重定向 URI 作为第一个参数(字符串值)传递,然后第二个参数是范围(要请求的权限数组)。

(是否要事先将这些值放入其他数组以进行配置,取决于您。

最新更新