Lumen中使用JWT-Auth刷新token实现方式

首先我们应该了解,JWT-Auth中Token是什么?

JWT实现的时候,一般会有两个过期时间

  • 第一个是Token本身的过期时间,这个时间一般1到2个小时,不能太长,也可以在短一点,不过5s的简直纯属扯淡。

  • 第二个是Token过期后,再次刷新的有效期,也就是Token过期后,你还有一段时间可以重新刷新,把过期的Token发给服务端,如果没有过刷新截止期,则服务端返回一个新的Token,不再需要通过用户名密码重新登录获取Token了。

所以为了减少过期后重新获取Token所带来的麻烦,我们一般在每次Http请求成功后,将目前的Token刷新,然后可以在Http响应中返回新的Token。

JWT由于过期数据(exp claim)是封装在Payload中的,所以必须返回一个新Token,而不是在旧Token的基础上刷新。

但是在并发的时候也会出现问题,如果前一个请求刷新了Token(为了安全,刷新后一般会把旧Token加入黑名单),后面的请求使用了一个旧的Token像服务请求数据,这个时候请求会被拒绝。

可以说这真的是JWT的一个缺陷,目前没有特别好的办法来解决并发刷新的问题。

下面说,实现方式

1、你可以写一个中间件

  1. $app->post('auth/refresh-token', ['middleware' => 'jwt.refresh'function() {  
  2.     try {  
  3.         $old_token = JWTAuth::getToken();  
  4.         $token = JWTAuth::refresh($old_token);  
  5.         JWTAuth::invalidate($old_token);  
  6.     } catch (TokenExpiredException $e) {  
  7.         throw new AuthException(  
  8.             Constants::get('error_code.refresh_token_expired'),  
  9.             trans('errors.refresh_token_expired'), $e);  
  10.     } catch (JWTException $e) {  
  11.         throw new AuthException(  
  12.             Constants::get('error_code.token_invalid'),  
  13.             trans('errors.token_invalid'), $e);  
  14.     }  
  15.   
  16.     return response()->json(compact('token'));  
  17. }]);  

2、你可以写一个方法,用路由调用

  /**
     * @api {put} /updateToken 刷新token(refresh token)
     * @apiDescription 刷新token(refresh token)
     * @apiGroup User
     */
    public function updateToken()
    {


        try {  
                $old_token = JWTAuth::getToken();  
                $token = JWTAuth::refresh($old_token);  
                JWTAuth::invalidate($old_token);  
                $cacheKey = 'token';
                Cache::forever($cacheKey,$token);
            } catch (TokenExpiredException $e) {  
                throw new AuthException(  
                trans('errors.refresh_token_expired'), $e);  
            } catch (JWTException $e) {  
                throw new AuthException(  
                trans('errors.token_invalid'), $e);  
            }  
            return response()->json(compact('token')); 

    }

 $api->put('updateToken','UserController@updateToken');


Lumen是一个基于Laravel框架的微型PHP框架,它可以用于构建轻量级的API服务。而Dingo是一个在Laravel框架上构建API的工具包。JWT(JSON Web Token)是一种用于进行身份验证和授权的开放标准。 在使用Lumen结合Dingo和JWT进行开发时,需要先安装Lumen服务提供者、JWT和Dingo的组件。可以使用Composer来管理这些依赖。确保你的电脑上安装了Composer。 在Lumen,你可以使用控制器来处理请求。引用是一个示例UserController。在这个控制器,我们注入了JWTAuth实例,并使用它来处理用户的登录请求。其,我们首先获取请求的参数,然后使用这些参数进行条件查询。如果登录认证成功,我们会返回一个包含JWT令牌的JSON响应。 对于跨域问题,你可以使用palanik/lumen-cors来解决。引用提供了安装和配置palanik/lumen-cors的方法。你需要通过Composer来安装该组件,并在bootstrap/app.php文件添加cors路由间件。 以上就是关于Lumen、Dingo和JWT的一些基本信息和配置方法。如果你有关于它们的更具体的问题,请告诉我。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Lumen 配合 JWT + Dingo 开发流程](https://blog.csdn.net/qq_44149053/article/details/89444892)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [lumen+dingo+jwt搭建api系统](https://blog.csdn.net/Chenlevin/article/details/111830096)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值