安裝
當前版本為 tymon/jwt-auth (1.0.0-rc.3)
通過composer安裝jwt-auth
composer require tymon/jwt-auth "1.*"
注意:jwt-auth 0.5.* 版本未對lumen做封裝
修改 自動加載配置 文件 bootstrap/app.php
- 去掉 withFacades() withEloquent() 的注釋
- 添加 jwt 接口
//使用 Facades 靜態類
$app->withFacades(true,[
'Tymon\JWTAuth\Facades\JWTAuth' => 'JWTAuth',
'Tymon\JWTAuth\Facades\JWTFactory' => 'JWTFactory'
]);
$app->withEloquent(); //使用 Eloquent ORM
- 去掉 auth 中間件 注釋
//auth 中間件
$app->routeMiddleware([
'auth' => App\Http\Middleware\Authenticate::class,
]);
- 去掉appServiceProvider的注釋,并且在 AppServiceProvider 中注冊 LumenServiceProvider
$app->register(App\Providers\AppServiceProvider::class);
$app->register(App\Providers\AuthServiceProvider::class);
//jwt 給 AppServiceProvider 中注冊 LumenServiceProvider
$app->register(\Tymon\JWTAuth\Providers\LumenServiceProvider::class);
// $app->register(App\Providers\EventServiceProvider::class);
jwt配置
- 獲取 auth 配置文件
在 lumen 根目錄下 創建 config 文件夾 (laravel 框架 自動加載 config 文件夾的內容),并將 vendor/laravel/lumen-framework/config 中的 auth.php 文件復制到剛剛創建的config文件夾中。修改 auth.php 文件,將 api 認證指定為 jwt,并綁定users 數據模型
//原
'guards' => [
'api' => ['driver' => 'api'],
],
//修改為:
'guards' => [
'api' => ['driver' => 'jwt'],
'provider' => 'users'
],
//指定數據模型
'providers' => [
//
'users' => [
'driver' => 'eloquent',
'model' => \App\Models\User::class,
],
],
- JWT 協議需要用到 secret,所以需要生成一個 secret,在根目錄下 執行命令
php artisan jwt:secret
//執行成功返回如下
jwt-auth secret [TfT42Dj1qm85vqjeJFGCb5RSFUlvari0] set successfully.
執行成功后,會把生成的secret寫入 .env 文件中
并配置jwt token 的三個時間
JWT_SECRET=TfT42Dj1qm85vqjeJFGCb5RSFUlvari0
//有效時間 單位:分鐘
JWT_TTL = 60
//刷新時間 單位:分鐘 默認 14天
JWT_REFRESH_TTL = 20160
//寬限時間 單位:秒
JWT_BLACKLIST_GRACE_PERIOD = 60
配置完成
參考:
https://blog.csdn.net/root_miss/article/details/82805370
http://www.lxweimin.com/p/7bb8fb395864