安裝
當(dāng)前版本為 tymon/jwt-auth (1.0.0-rc.3)
通過composer安裝jwt-auth
composer require tymon/jwt-auth "1.*"
注意:jwt-auth 0.5.* 版本未對(duì)lumen做封裝
修改 自動(dòng)加載配置 文件 bootstrap/app.php
- 去掉 withFacades() withEloquent() 的注釋
- 添加 jwt 接口
//使用 Facades 靜態(tài)類
$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 根目錄下 創(chuàng)建 config 文件夾 (laravel 框架 自動(dòng)加載 config 文件夾的內(nèi)容)遍蟋,并將 vendor/laravel/lumen-framework/config 中的 auth.php 文件復(fù)制到剛剛創(chuàng)建的config文件夾中卓箫。修改 auth.php 文件麻裳,將 api 認(rèn)證指定為 jwt幕垦,并綁定users 數(shù)據(jù)模型
//原
'guards' => [
'api' => ['driver' => 'api'],
],
//修改為:
'guards' => [
'api' => ['driver' => 'jwt'],
'provider' => 'users'
],
//指定數(shù)據(jù)模型
'providers' => [
//
'users' => [
'driver' => 'eloquent',
'model' => \App\Models\User::class,
],
],
- JWT 協(xié)議需要用到 secret未荒,所以需要生成一個(gè) secret哩罪,在根目錄下 執(zhí)行命令
php artisan jwt:secret
//執(zhí)行成功返回如下
jwt-auth secret [TfT42Dj1qm85vqjeJFGCb5RSFUlvari0] set successfully.
執(zhí)行成功后呀狼,會(huì)把生成的secret寫入 .env 文件中
并配置jwt token 的三個(gè)時(shí)間
JWT_SECRET=TfT42Dj1qm85vqjeJFGCb5RSFUlvari0
//有效時(shí)間 單位:分鐘
JWT_TTL = 60
//刷新時(shí)間 單位:分鐘 默認(rèn) 14天
JWT_REFRESH_TTL = 20160
//寬限時(shí)間 單位:秒
JWT_BLACKLIST_GRACE_PERIOD = 60
配置完成
參考:
https://blog.csdn.net/root_miss/article/details/82805370
http://www.reibang.com/p/7bb8fb395864