主页 > 知识库 > Laravel (Lumen) 解决JWT-Auth刷新token的问题

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

热门标签:电销机器人没有效果怎么样 杭州语音电销机器人 江门回拨外呼系统 江西电销机器人收费 高德地图标注店铺收费吗 泊头在哪里办理400电话 高德地图标注位置怎么标注 欣思维地图标注 天润融通外呼系统好吗

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的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • laravel5.5安装jwt-auth 生成token令牌的示例
  • Laravel jwt 多表(多用户端)验证隔离的实现
  • Laravel配合jwt使用的方法实例

标签:驻马店 平凉 大同 石嘴山 深圳 江门 内江 双鸭山

巨人网络通讯声明:本文标题《Laravel (Lumen) 解决JWT-Auth刷新token的问题》,本文关键词  Laravel,Lumen,解决,JWT-Auth,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Laravel (Lumen) 解决JWT-Auth刷新token的问题》相关的同类信息!
  • 本页收集关于Laravel (Lumen) 解决JWT-Auth刷新token的问题的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章