安装
当前版本为 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
https://www.jianshu.com/p/7bb8fb395864