Laravel (Lumen) 解决JWT-Auth刷新token的问题


Posted in PHP onOctober 24, 2019

Laravel(Lumen)中使用JWT-Auth遇到一个问题,即token如何刷新。

一开始不太理解作者的设计思想,看了很多issue之后,慢慢明白jwt-refresh如何使用。

建一个路由,比如“auth/refresh-token” ,可以指向某个方法,也可以直接写个匿名函数。

$app->post('auth/refresh-token', ['middleware' => 'jwt.refresh', function() {
  try {
    $old_token = JWTAuth::getToken();
    $token = JWTAuth::refresh($old_token);
    JWTAuth::invalidate($old_token);
  } catch (TokenExpiredException $e) {
    throw new AuthException(
      Constants::get('error_code.refresh_token_expired'),
      trans('errors.refresh_token_expired'), $e);
  } catch (JWTException $e) {
    throw new AuthException(
      Constants::get('error_code.token_invalid'),
      trans('errors.token_invalid'), $e);
  }
 
  return response()->json(compact('token'));
}]);

当token失效之后,访问这个地址,把旧token带上,会得到一个新的token。自己将新token保存,访问api时使用新token。如此反复。

虽然token的有效很短,默认是一个小时,但是刷新时间长达两个星期,还算可以,总比重复登录来得方便。

客户端登录之后只要保存token,减少了被获取用户名密码的风险。

这个地方有个bug,就是旧token虽然不能再使用,但是却可以用来获取新token。这个问题在0.6版中被修复。如果着急这个问题可以使用0.6版。

一开始以为一个token刷新之后可以接着用,原来是换个新token,不知道接着用的思想是否可行。

以上这篇Laravel (Lumen) 解决JWT-Auth刷新token的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php include,include_once,require,require_once
Sep 05 PHP
一贴学会PHP 新手入门教程
Aug 03 PHP
php下删除一篇文章生成的多个静态页面
Aug 08 PHP
Zend Studio去除编辑器的语法警告设置方法
Oct 24 PHP
php启动时候提示PHP startup的解决方法
May 07 PHP
php+mysqli实现批量替换数据库表前缀的方法
Dec 29 PHP
php中Socket创建与监听实现方法
Jan 05 PHP
支持中文、字母、数字的PHP验证码
May 04 PHP
Zend Framework框架之Zend_Mail实现发送Email邮件验证功能及解决标题乱码的方法
Mar 21 PHP
php+redis在实际项目中HTTP 500: Internal Server Error故障排除
Feb 05 PHP
实例说明js脚本语言和php脚本语言的区别
Apr 04 PHP
解决php用mysql方式连接数据库出现Deprecated报错问题
Dec 25 PHP
laravel5.1 ajax post 传值_token示例
Oct 24 #PHP
laravel 5.5 关闭token的3种实现方式
Oct 24 #PHP
Thinkphp 3.2框架使用Redis的方法详解
Oct 24 #PHP
laravel解决迁移文件一次删除创建字段报错的问题
Oct 24 #PHP
PHP Swoole异步读取、写入文件操作示例
Oct 24 #PHP
PHP Swoole异步Redis客户端实现方法示例
Oct 24 #PHP
Laravel自动生成UUID,从建表到使用详解
Oct 24 #PHP
You might like
PHP链表操作简单示例
2016/10/15 PHP
PHP实现模拟http请求的方法分析
2017/12/20 PHP
Laravel 队列使用的实现
2019/01/08 PHP
避免回车键导致的页面无意义刷新的解决方法
2011/04/12 Javascript
JavaScript的parseInt 取整使用
2011/05/09 Javascript
jquery选择器、属性设置用法经验总结
2013/09/08 Javascript
javascript自启动函数的问题探讨
2013/10/05 Javascript
理解 Node.js 事件驱动机制的原理
2017/08/16 Javascript
webpack处理 css\less\sass 样式的方法
2017/08/21 Javascript
Vue.js与 ASP.NET Core 服务端渲染功能整合
2017/11/16 Javascript
详解ES6中的代理模式——Proxy
2018/01/08 Javascript
Puppeteer环境搭建的详细步骤
2018/09/21 Javascript
ES6中字符串的使用方法扩展
2019/06/04 Javascript
layer.prompt输入层的例子
2019/09/24 Javascript
小程序表单认证布局及验证详解
2020/06/19 Javascript
JavaScript实现多层颜色选项卡嵌套
2020/09/21 Javascript
Vue中ref和$refs的介绍以及使用方法示例
2021/01/11 Vue.js
[20:21]《一刀刀一天》第十六期:TI国际邀请赛正式打响,总奖金超过550万
2014/05/23 DOTA
python爬虫的工作原理
2017/03/05 Python
python脚本实现验证码识别
2018/06/07 Python
Tensorflow不支持AVX2指令集的解决方法
2020/02/03 Python
python deque模块简单使用代码实例
2020/03/12 Python
基于TensorFlow的CNN实现Mnist手写数字识别
2020/06/17 Python
利用Python实现最小二乘法与梯度下降算法
2021/02/21 Python
浅谈html5增强的页面元素
2016/06/14 HTML / CSS
英国著名的小众美容品牌网站:Alyaka
2017/08/08 全球购物
Foot Locker德国官方网站:美国运动服和鞋类零售商
2018/11/01 全球购物
普罗米修斯教学反思
2014/02/06 职场文书
美术教师自我鉴定
2014/02/12 职场文书
置业顾问岗位职责
2014/03/02 职场文书
社会实践活动总结范文
2014/07/03 职场文书
2015年安全月活动总结
2015/03/26 职场文书
2015年度内部审计工作总结
2015/05/20 职场文书
同事离别感言
2015/08/04 职场文书
vue使用Google Recaptcha验证的实现示例
2021/08/23 Vue.js
Spring依赖注入多种类型数据的示例代码
2022/03/31 Java/Android