PHP Firebase help — настройка JWT

На моем сервере я использую несколько файлов PHP, которые читают мою базу данных Firebase Realtime. В соответствии с Документы Firebase Мне нужно настроить пользовательский токен, чтобы получить мой PHP-клиент Firebase Бег. Документ Firebase говорит, что мне нужно это вернуть;

  return JWT::encode($payload, $private_key, "RS256");

Как именно я ссылаюсь на класс JWT? Я скачал библиотеку JWT, но я не уверен, как внедрить это в мой проект. Любая помощь была бы отличной, я в основном разработчик мобильных приложений и имею небольшой опыт работы с PHP.

5

Решение

Библиотека firebase / php-jwt использует композитор. Composer — это менеджер зависимостей для PHP, похожий на Maven в Java, если вы работаете в среде разработки Android. Вам необходимо знать, как импортировать классы в php, используя функции require / include из php. Вам понадобится некоторый опыт работы с php, чтобы использовать composer.

Чтобы использовать библиотеку firebase / php-jwt без композитора, вы можете использовать следующий пример кода: (Я загрузил библиотеку в папке ‘jwt’)

<?php

require_once 'jwt/src/BeforeValidException.php';
require_once 'jwt/src/ExpiredException.php';
require_once 'jwt/src/SignatureInvalidException.php';
require_once 'jwt/src/JWT.php';use \Firebase\JWT\JWT;

$key = "example_key";
$token = array(
"iss" => "http://example.org",
"aud" => "http://example.com",
"iat" => 1356999524,
"nbf" => 1357000000
);

/**
* IMPORTANT:
* You must specify supported algorithms for your application. See
* https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40
* for a list of spec-compliant algorithms.
*/
$jwt = JWT::encode($token, $key);
$decoded = JWT::decode($jwt, $key, array('HS256'));

print_r($decoded);

/*
NOTE: This will now be an object instead of an associative array. To get
an associative array, you will need to cast it as such:
*/

$decoded_array = (array) $decoded;

/**
* You can add a leeway to account for when there is a clock skew times   between
* the signing and verifying servers. It is recommended that this leeway should
* not be bigger than a few minutes.
*
* Source: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#nbfDef
*/
JWT::$leeway = 60; // $leeway in seconds
$decoded = JWT::decode($jwt, $key, array('HS256'));
?>
18

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]