matiasnamendola / slimpower-jwt
A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming to RFC 7519
v0.0.1-alpha
2016-12-07 02:33 UTC
Requires
- php: >=5.3.0
- symfony/yaml: v2.6.0
This package is not auto-updated.
Last update: 2024-11-09 20:50:57 UTC
README
A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming to RFC 7519.
Installation
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" } }
Example
<?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')); ?>
Credits
License
The MIT License (MIT). Please see License File for more information.