byjg / jwt-wrapper
A very simple wrapper for create, encode, decode JWT Tokens and abstract the PHP JWT Component
Fund package maintenance!
byjg
Installs: 92 827
Dependents: 3
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 4
Open Issues: 1
pkg:composer/byjg/jwt-wrapper
Requires
- php: >=8.1 <8.4
- ext-openssl: *
- firebase/php-jwt: ^6
Requires (Dev)
- phpunit/phpunit: ^9.6
- vimeo/psalm: ^5.9
README
PHP JWT Wrapper
A simple and flexible wrapper around the Firebase JWT library that makes JWT token handling easy and intuitive in PHP applications.
Features
- Simple API: Create and validate JWT tokens with minimal code
- Flexible Signing: Support for both HMAC (shared secret) and RSA/ECDSA (public/private key) methods
- Automatic Claims: Built-in handling of standard JWT claims (iat, exp, nbf)
- HTTP Integration: Helper methods for extracting tokens from HTTP headers
- Key Management: Intuitive interfaces for different key types
Installation
composer require "byjg/jwt-wrapper"
Quick Example
// Create a JWT token using HMAC $server = "example.com"; $secret = new \ByJG\JwtWrapper\JwtHashHmacSecret(base64_encode("your_secret_key")); $jwtWrapper = new \ByJG\JwtWrapper\JwtWrapper($server, $secret); // Add custom data and set expiration $token = $jwtWrapper->generateToken( $jwtWrapper->createJwtData(["userId" => 123], 3600) ); // Validate and extract data try { $jwtData = $jwtWrapper->extractData($token); $userId = $jwtData->data->userId; } catch (\ByJG\JwtWrapper\JwtWrapperException $e) { // Handle invalid token }
Documentation
Detailed documentation:
| Document | Description |
|---|---|
| Overview | Introduction and core concepts |
| Key Types | HMAC and OpenSSL key configuration |
| Creating Tokens | Token generation and customization |
| Validating Tokens | Token validation and data extraction |
| API Reference | Complete class and method documentation |
Examples
The library includes complete examples in the example directory showing:
- Token creation with login.php
- Token validation with api.php
- Client-side usage with client.html
sequenceDiagram
participant LOCAL
participant CLIENT
participant SERVER
participant PRIVATE_RESOURCE
LOCAL->>CLIENT: Retrieve Local Token
CLIENT->>SERVER: Pass Token
SERVER->>PRIVATE_RESOURCE: Validate Token
PRIVATE_RESOURCE->>CLIENT: Return Result if token is valid
CLIENT->>LOCAL: Store Token
Loading
Running the tests
vendor/bin/phpunit
Dependencies
flowchart TD
byjg/jwt-wrapper --> firebase/php-jwt
byjg/jwt-wrapper --> ext-openssl
Loading