yaobiao / think-jwt
ThinkPHP Jwt Component
Installs: 106
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 18
Type:think-extend
Requires
- php: >=8.0
- ext-json: *
- ext-mbstring: *
- lcobucci/jwt: 4.1.4
- nette/php-generator: ^3.2
- topthink/framework: ^6.0.2
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.1.0
- mockery/mockery: ^1.2
- phpstan/phpstan: ^0.12.0
- phpunit/phpunit: ^9.5.9
- symfony/var-dumper: 5.0.x-dev
- dev-master
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v1.0.0-beta.18
- v1.0.0-beta.17
- v1.0.0-beta.16
- v1.0.0-beta.15
- v1.0.0-beta.14
- v1.0.0-beta.13
- v1.0.0-beta.12
- v1.0.0-beta.11
- v1.0.0-beta.10
- v1.0.0-beta.9
- v1.0.0-beta.8
- v1.0.0-beta.7
- v1.0.0-beta.6
- v1.0.0-beta.5
- v1.0.0-beta.4
- v1.0.0-beta.3
- v1.0.0-beta.2
- v0.8.0
- v0.7.1
- v0.7.0
- v0.6.3
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.3
- v0.5.2
- v0.5.1
- v0.5.0
- dev-next
- dev-dev
This package is auto-updated.
Last update: 2025-04-29 01:10:46 UTC
README
只支持 thinkphp 6.0
安装
稳定版
$ composer require xiaodi/think-jwt
开发版
$ composer require xiaodi/think-jwt:dev-master
使用
- 命令生成签名key
$ php think jwt:make
- 配置
config/jwt.php
完整多应用配置
<?php return [ 'default' => 'admin', 'apps' => [ 'admin' => [ 'token' => [ 'uniqidKey' => 'uid', 'signerKey' => '', 'notBefore' => 0, 'expiresAt' => 3600, 'refreshTTL' => 7200, 'signer' => 'Lcobucci\JWT\Signer\Hmac\Sha256', 'type' => 'Header', 'refresh' => 50001, 'relogin' => 50002, 'iss' => '', 'aud' => '', 'automaticRenewal' => false, ], 'user' => [ 'bind' => false, 'model' => '', ] ] ], 'manager' => [ // 缓存前缀 'prefix' => 'jwt', // 黑名单缓存名 'blacklist' => 'blacklist', // 白名单缓存名 'whitelist' => 'whitelist' ] ];
token
uniqidKey
用户唯一标识signerKey
密钥notBefore
时间前不能使用 默认生成后直接使用expiresAt
Token有效期(秒)signer
加密算法type
获取 Token 途径refresh
Token过期抛异常code = 50001relogin
Token失效异常code = 50002automaticRenewal
开启过期自动续签
user
bind
是否注入用户模型(中间件有效)model
用户模型文件
blacklist
cacheKey
黑名单缓存key
以下两个异常都会抛一个HTTP异常 StatusCode = 401
xiaodi\Exception\HasLoggedException
xiaodi\Exception\TokenAlreadyEexpired
Token 生成
use xiaodi\JWTAuth\Facade\Jwt; public function login() { //...登录判断逻辑 // 默认应用 return json([ 'token' => Jwt::token(['uid' => 1]), 'token_type' => Jwt::type(), 'expires_in' => Jwt::ttl(), 'refresh_in' => Jwt::refreshTTL() ]); // 指定应用 return json([ 'token' => Jwt::store('wechat')->token(['uid' => 1]), 'token_type' => Jwt::type(), 'expires_in' => Jwt::ttl(), 'refresh_in' => Jwt::refreshTTL() ]); }
Token 验证
手动验证
use xiaodi\JWTAuth\Facade\Jwt; use xiaodi\JWTAuth\Exception\HasLoggedException; use xiaodi\JWTAuth\Exception\TokenAlreadyEexpired; class User { public function test() { try { // 默认应用 Jwt::verify($token); // 指定应用 // Jwt::store('wechat')->verify($token); } catch (HasLoggedException $e) { // 已在其它终端登录 } catch (TokenAlreadyEexpired $e) { // Token已过期 } // 验证成功 // 如 开启用户注入功能 可获取当前用户信息 dump(Jwt::user()); } }
路由验证
use xiaodi\JWTAuth\Middleware\Jwt; // 默认应用 Route::get('/hello', 'index/index')->middleware(Jwt::class); // 指定应用 Route::get('/hello', 'index/index')->middleware(Jwt::class, 'wechat');
Token 自动获取
支持以下方式自动获取
Header
Cookie
Url
赋值方式
类型 | 途径 | 标识 |
---|---|---|
Header | Authorization | Bearer Token |
Cookie | Cookie | token |
Url | Request | token |
# config/jwt.php <?php return [ 'apps' => [ 'admin' => [ 'token' => [ // ...其它配置 'type' => 'Header', // 'type' => 'Cookie', // 'type' => 'Url', // 支持多种方式获取 // 'type' => 'Header|Url', ] ] ] ];
过期自动续签
app/config/jwt.php
automaticRenewal => true
系统检测到 Token 已过期, 会自动续期并返回以下 header 信息。
- Automatic-Renewal-Token
- Automatic-Renewal-Token-RefreshAt
前端需要接收最新 Token,下次异步请求时,携带此 Token。
注销应用Token
注销指定应用下缓存的用户 (强制下线 重新登录)
$store = 'wechat'; app('jwt.manager')->resetStoreWhiteToken($store);