Szukaj…


Utwórz aplikację na deweloperze Facebooka

Przejdź do [ https://developers.facebook.com/](https://developers.facebook.com/) i utwórz aplikację. Interfejs po utworzeniu nowej aplikacji

Kliknij Add product i wybierz Facebook Login

Ustawienie logowania do aplikacji na Facebooku

Zainstaluj yii2-authclient

Przed zainstalowaniem tego rozszerzenia musisz zainstalować aplikację yii2. W tym przykładzie używam szablonu yii2-basic. Przewodnik instalacji tutaj .

Biegać

composer require --prefer-dist yiisoft/yii2-authclient

lub dodaj

"yiisoft/yii2-authclient": "~2.1.0"

do require sekcji pliku composer.json .

Dodaj config authClientCollection do swoich components konfiguracji:

return [
    'components' => [
        'authClientCollection' => [
            'class' => 'yii\authclient\Collection',
            'clients' => [
                'facebook' => [
                    'class' => 'yii\authclient\clients\Facebook',
                    'clientId' => 'facebook_client_id',
                    'clientSecret' => 'facebook_client_secret',
                ],
            ],
        ]
    ],
    // ...
];

facebook_client_id to identyfikator aplikacji, a facebook_client_secret to tajna aplikacja. Informacje o identyfikatorze klienta Facebook i tajnym kliencie

Dodaj działanie uwierzytelniania i skonfiguruj wywołanie zwrotne

  1. Dodaj przycisk Login as facebook account na Login as facebook account do widoku logowania:

Edytuj site/login.php w folderze wyświetleń, dodaj tezę do zawartości strony logowania:

<?= yii\authclient\widgets\AuthChoice::widget([
     'baseAuthUrl' => ['site/auth'],
     'popupMode' => false,
]) ?>

Powyżej, możemy ustawić, że auth działanie w SiteController będzie handler przepływ OAuth2.

Teraz go tworzymy.

class SiteController extends Controller
{
    public function actions()
    {
        return [
            'auth' => [
                'class' => 'yii\authclient\AuthAction',
                'successCallback' => [$this, 'onAuthSuccess'],
            ],
        ];
    }

    public function onAuthSuccess($client)
    {
        // do many stuff here, save user info to your app database
    }
}

Używamy yii\authclient\AuthAction do utworzenia yii\authclient\AuthAction URL i przekierowania na stronę logowania na Facebooku.

Funkcja onAuthSuccess służy do uzyskiwania informacji o użytkowniku, logowania do aplikacji.

Dodaj redirect_url do ustawienia aplikacji na Facebooku

Jeśli włączysz prettyUrl w swojej aplikacji yii2, twój redirect_uri będzie:

http://<base_url>/web/site/auth

I wyłącz ładny adres URL:

http://<base_url>/web/index.php?r=site%2Fauth

Przykład:

Skonfiguruj redirect_uri

Przykład funkcji onAuthSuccess

/**
 * @param $client ClientInterface
 */
public function onAuthSuccess($client)
{
    //Get user info
    /** @var array $attributes */
    $attributes = $client->getUserAttributes();
    $email = ArrayHelper::getValue($attributes, 'email'); //email info
    $id = ArrayHelper::getValue($attributes, 'id'); // id facebook user
    $name = ArrayHelper::getValue($attributes, 'name'); // name facebook account

    //Login user
    //For demo, I will login with admin/admin default account
    $admin = User::findByUsername('admin');
    Yii::$app->user->login($admin);
}


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow