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

This package is not auto-updated.

Last update: 2024-04-13 18:08:00 UTC


README

Latest version Total Downloads

Latest Stable Version Latest Unstable Version Total Downloads Monthly Downloads Daily Downloads composer.lock available

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.