A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming to RFC 7519.
In terminal, use composer to manage your dependencies and download 'Slimpower JWT':
composer require matiasnamendola/slimpower-jwt
Or you can add use this as your composer.json:
{
"require": {
"matiasnamendola/slimpower-jwt": "dev-master"
}
}
<?php
use \SlimPower\JWT\JWT;
$key = "secret";
$token = array(
"iss" => "http://example.org",
"aud" => "http://example.com",
"iat" => 1481113105,
"nbf" => 1481000000
);
/**
* 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'));
?>
The MIT License (MIT). Please see License File for more information.