Adhocore/php-jwt: Ultra Lightweight, Dependency Free And ... - GitHub

Skip to content Dismiss alert {{ message }} / php-jwt Public
  • Notifications You must be signed in to change notification settings
  • Fork 20
  • Star 297

Ultra lightweight, dependency free and standalone JSON web token (JWT) library for PHP5.6 to PHP8.2. This library makes JWT a cheese. It is a minimal JWT integration for PHP.

github.com/adhocore/php-jwt

License

MIT license 297 stars 20 forks Branches Tags Activity Star Notifications You must be signed in to change notification settings
  • Code
  • Issues 2
  • Pull requests 2
  • Actions
  • Projects
  • Security
  • Insights
Additional navigation options adhocore/php-jwt  mainBranchesTagsGo to fileCode

Folders and files

NameNameLast commit messageLast commit date

Latest commit

 

History

120 Commits
.github.github  
srcsrc  
teststests  
.editorconfig.editorconfig  
.gitignore.gitignore  
CHANGELOG.mdCHANGELOG.md  
LICENSELICENSE  
README.mdREADME.md  
VERSIONVERSION  
composer.jsoncomposer.json  
phpunit.xml.distphpunit.xml.dist  
test.phptest.php  
View all files

Repository files navigation

  • README
  • MIT license

adhocore/jwt

If you are new to JWT or want to refresh your familiarity with it, please check jwt.io

Latest Version Build Scrutinizer CI Codecov branch StyleCI Software License Tweet Support

  • Lightweight JSON Web Token (JWT) library for PHP7, PHP8 and beyond.
  • Zero dependency (no vendor bloat).
  • If you still use PHP5.6, use version 0.1.2

Installation

# PHP7.x, PHP8.x composer require adhocore/jwt # PHP5.6 (deprecated) composer require adhocore/jwt:0.1.2 # For PHP5.4-5.5 (deprecated), use version 0.1.2 with a polyfill for https://php.net/hash_equals

Features

  • Six algorithms supported:
'HS256', 'HS384', 'HS512', 'RS256', 'RS384', 'RS512'
  • kid support.
  • Leeway support 0-120 seconds.
  • Timestamp spoofing for tests.
  • Passphrase support for RS* algos.

Usage

use Ahc\Jwt\JWT; // Instantiate with key, algo, maxAge and leeway. $jwt = new JWT('secret', 'HS256', 3600, 10);

Only the key is required. Defaults will be used for the rest:

$jwt = new JWT('secret'); // algo = HS256, maxAge = 3600, leeway = 0

For RS* algo, the key should be either a resource like below:

$key = openssl_pkey_new([ 'digest_alg' => 'sha256', 'private_key_bits' => 1024, 'private_key_type' => OPENSSL_KEYTYPE_RSA, ]);

OR, a string with full path to the RSA private key like below:

$key = '/path/to/rsa.key'; // Then, instantiate JWT with this key and RS* as algo: $jwt = new JWT($key, 'RS384');

Pro You dont need to specify pub key path, that is deduced from priv key.

Generate JWT token from payload array:

$token = $jwt->encode([ 'uid' => 1, 'aud' => 'http://site.com', 'scopes' => ['user'], 'iss' => 'http://api.mysite.com', ]);

Retrieve the payload array:

$payload = $jwt->decode($token);

Oneliner:

$token = (new JWT('topSecret', 'HS512', 1800))->encode(['uid' => 1, 'scopes' => ['user']]); $payload = (new JWT('topSecret', 'HS512', 1800))->decode($token);

Pro

Can pass extra headers into encode() with second parameter:

$token = $jwt->encode($payload, ['hdr' => 'hdr_value']);

Test mocking

Spoof time() for testing token expiry:

$jwt->setTestTimestamp(time() + 10000); // Throws Exception. $jwt->parse($token);

Call again without parameter to stop spoofing time():

$jwt->setTestTimestamp();

Examples with kid

$jwt = new JWT(['key1' => 'secret1', 'key2' => 'secret2']); // Use key2 $token = $jwt->encode(['a' => 1, 'exp' => time() + 1000], ['kid' => 'key2']); $payload = $jwt->decode($token); $token = $jwt->encode(['a' => 1, 'exp' => time() + 1000], ['kid' => 'key3']); // -> Exception with message Unknown key ID key3

Stabillity

The library is now marked at version 1.*.* as being stable in functionality and API.

Integration

Phalcon

Check adhocore/phalcon-ext.

Consideration

Be aware of some security related considerations as outlined here which can be valid for any JWT implementations.

About

Ultra lightweight, dependency free and standalone JSON web token (JWT) library for PHP5.6 to PHP8.2. This library makes JWT a cheese. It is a minimal JWT integration for PHP.

github.com/adhocore/php-jwt

Topics

php jwt oauth2 php7 php-jwt jwt-authentication json-web-signature json-web-token jwt-auth php8 api-security json-web-token-php api-auth adhocore

Resources

Readme

License

MIT license Activity

Stars

297 stars

Watchers

10 watching

Forks

20 forks Report repository

Releases 14

Version 1.1.2 Latest Feb 20, 2021 + 13 releases

Sponsor this project

  • https://paypal.me/ji10
Learn more about GitHub Sponsors

Contributors 8

Languages

  • PHP 100.0%
You can’t perform that action at this time.

Từ khóa » Jwt Php Github