信息发布→ 登录 注册 退出

Использование dicr/yii2-google для интеграции Google API в Yii2

发布时间:2025-03-16

点击量:

Для тех, кто хочет глубже изучить composer и подобные библиотеки, доступен следующий ресурс: учебный материал.

Использование библиотеки dicr/yii2-google позволяет легко настроить компонент для работы с Google API в Yii2. Вот как это можно сделать:

Настройка компонента

Для начала, необходимо настроить компонент в конфигурационном файле вашего приложения. Пример конфигурации выглядит следующим образом:

'components' => [
    'google' => [
        'class' => dicr\google\Google::class,
        'clientConfig' => [
            'client_id' => 'XXXXXXX.apps.googleusercontent.com',
            'access_type' => 'offline',
            'prompt' => 'select_account consent',
            'client_secret' => 'XXXXXXXX', // для простой авторизации
            'credentials' => 'xxx', // см. Client::setAuthConfig
            'scopes' => [           // см. Client::setScopes
                Google_Service_Sheets::SPREADSHEETS,
                Google_Service_Sheets::DRIVE,
                Google_Service_Sheets::DRIVE_FILE
            ],
            'include_granted_scopes' => true
        ]
    ]
];

Этот код настраивает компонент google с необходимыми параметрами для работы с Google API. Важно правильно указать client_id, client_secret, а также необходимые scopes для доступа к нужным сервисам.

Проверка валидности текущего токена

После настройки компонента, важно убедиться, что токен доступа действителен. Вот пример кода, который проверяет валидность токена и при необходимости обновляет его или отправляет пользователя на страницу авторизации:

use Google\Client;
use yii\helpers\Url;

/** @var dicr\google\Google $google */
$google = Yii::$app->get('google');

/** @var Client $client */
$client = $google->client;

// попробуем обновить токен через refresh_token, если имеется
if ($client->isAccessTokenExpired() && !empty($client->getRefreshToken())) {
    $token = $client->fetchAccessTokenWithRefreshToken();
    if (!empty($token)) {
        // сохраняем токен в сессии
        $this->module->api->sessionToken = $token;
    }
}

// если обновить не получилось, тогда переходим на страницу авторизации
if ($client->isAccessTokenExpired()) {
    // сохраняем адрес возврата
    Yii::$app->user->returnUrl = Url::current();

    // настраиваем адрес обработчика кода ответа
    $client->setRedirectUri(Url::to(['my-module/google-callback'], true));

    // отправляем пользователя на страницу авторизации
    return $this->redirect($client->createAuthUrl(), 303);
}

Этот код проверяет, истек ли срок действия текущего токена доступа, и если да, пытается обновить его с помощью refresh_token. Если обновление не удается, пользователь перенаправляется на страницу авторизации Google для получения нового токена.

Преимущества и практическое применение

Использование dicr/yii2-google значительно упрощает интеграцию с Google API в Yii2. Библиотека предоставляет удобный интерфейс для управления аутентификацией и доступом к различным сервисам Google, что экономит время и силы разработчика. В моем проекте это позволило быстро и эффективно реализовать функционал работы с Google Sheets и Google Drive, что было бы значительно сложнее без этой библиотеки.

В итоге, использование dicr/yii2-google оказалось отличным решением для интеграции с Google API, позволив мне сосредоточиться на других аспектах разработки, а не на тонкостях работы с API.

标签:# composer  # access  # red  # XXXXXXXX  # client_secret  # credentials  # Client  # xxx  # offline  # access_type  # prompt  # consent  # select_account  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!