在 header 中放置什么才能正确使用 Facebook PHP web SDK?

What to place in header to use the Facebook PHP web SDK properly?

我有一个带有有效用户注册和登录系统的网站。最近,我决定添加 Facebook 注册选项。我希望在注册页面中添加一个 Facebook 登录按钮,并在登录时获取他们的电子邮件、名字和姓氏,这样他们就不必插入详细信息。

我阅读了大部分 Facebook 开发人员帮助文档,包括:

https://developers.facebook.com/docs/php/howto/example_facebook_login

https://developers.facebook.com/docs/php/howto/example_retrieve_user_profile

这些链接告诉我如何让用户登录以及如何从他们的个人资料中获取用户数据。

我了解所有这些部分的工作原理,但我不知道如何将它们组合在一起。谁能教我怎么做?非常感谢!

好的,我终于找到了怎么做...

所以,第一部分是正确设置文件。以下是您的操作方法:

  1. 从 fb 下载 php sdk 套件 (here)

  2. 将"src"文件夹中的文件放到网站主目录

第二部分是用fblink制作你想要的页面:

  1. 在您的 php 页面中包含 fb 自动加载页面 require_once 'autoload.php'; 在文件的顶部
  2. 通过放置

    授权 fb 使用您的应用程序

    $fb = 新 Facebook\Facebook([ 'app_id' => 'XXXXXXXXXXXXXXXX', 'app_secret' => 'XXXXXXXXXXXXXXXXXXXXXXXXXX', 'default_graph_version' => 'v2.6', ]);

在第一步的代码之后

这基本上就是您应该如何使用 fb 用户配置文件启动您的代码 link。以下代码是我用来获取用户名、电子邮件和个人资料图片的代码。

<?php
session_start();
require_once 'Facebook/autoload.php';

$fb = new Facebook\Facebook([
  'app_id' => 'XXXXXXXXXXXXXXXX',
  'app_secret' => 'XXXXXXXXXXXXXXXXXXXXXXXXXX',
  'default_graph_version' => 'v2.6',
  ]);

$helper = $fb->getRedirectLoginHelper();

$permissions = ['email']; // optional

try {
    if (isset($_SESSION['facebook_access_token'])) {
        $accessToken = $_SESSION['facebook_access_token'];
    } else {
        $accessToken = $helper->getAccessToken();
    }
} catch(Facebook\Exceptions\FacebookResponseException $e) {
    // When Graph returns an error
    echo 'Graph returned an error: ' . $e->getMessage();

    exit;
} catch(Facebook\Exceptions\FacebookSDKException $e) {
    // When validation fails or other local issues
    echo 'Facebook SDK returned an error: ' . $e->getMessage();
    exit;
 }

if (isset($accessToken)) {
    if (isset($_SESSION['facebook_access_token'])) {
        $fb->setDefaultAccessToken($_SESSION['facebook_access_token']);
    } else {
        // getting short-lived access token
        $_SESSION['facebook_access_token'] = (string) $accessToken;

        // OAuth 2.0 client handler
        $oAuth2Client = $fb->getOAuth2Client();

        // Exchanges a short-lived access token for a long-lived one
        $longLivedAccessToken = $oAuth2Client->getLongLivedAccessToken($_SESSION['facebook_access_token']);

        $_SESSION['facebook_access_token'] = (string) $longLivedAccessToken;

        // setting default access token to be used in script
        $fb->setDefaultAccessToken($_SESSION['facebook_access_token']);
    }

    // redirect the user back to the same page if it has "code" GET variable
    if (isset($_GET['code'])) {
        header('Location: ./');
    }

    // getting basic info about user
    try {
        $profile_request = $fb->get('/me?fields=name,first_name,last_name,email');
        $requestPicture = $fb->get('/me/picture?redirect=false&height=300');
        $picture = $requestPicture->getGraphUser();

        $profile = $profile_request->getGraphNode()->asArray();
    } catch(Facebook\Exceptions\FacebookResponseException $e) {
        // When Graph returns an error
        echo 'Graph returned an error: ' . $e->getMessage();
        session_destroy();
        // redirecting user back to app login page
        header("Location: ./");
        exit;
    } catch(Facebook\Exceptions\FacebookSDKException $e) {
        // When validation fails or other local issues
        echo 'Facebook SDK returned an error: ' . $e->getMessage();
        exit;
    }

    // printing $profile array on the screen which holds the basic info about user

    // Now you can redirect to another page and use the access token from $_SESSION['facebook_access_token']
} else {
    // replace your website URL same as added in the developers.facebook.com/apps e.g. if you used http instead of https and you used non-www version or www version of your website then you must add the same here
$loginUrl = $helper->getLoginUrl('http://xxxxx', $permissions);    
echo '<META HTTP-EQUIV="refresh" content="0;URL=' . $loginUrl . '">';}
?>

希望能帮到和我一样卡的小伙伴,再见~