RefreshToken.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Tymon\JWTAuth\Exceptions\JWTException;
  5. use Tymon\JWTAuth\Http\Middleware\BaseMiddleware;
  6. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  7. use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException;
  8. use Tymon\JWTAuth\JWTAuth;
  9. /**
  10. * token 验证
  11. * Class RefreshToken
  12. * @package App\Http\Middleware
  13. */
  14. class RefreshToken extends BaseMiddleware
  15. {
  16. /**
  17. * @param $request
  18. * @param Closure $next
  19. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response|mixed
  20. * @throws JWTException
  21. */
  22. public function handle($request, Closure $next)
  23. {
  24. // 检查此次请求中是否带有 token,如果没有则抛出异常。
  25. $this->checkForToken($request);
  26. // 使用 try 包裹,以捕捉 token 过期所抛出的 TokenExpiredException 异常
  27. try {
  28. // 检测用户的登录状态,如果正常则通过
  29. if ($this->auth->parseToken()->authenticate()) {
  30. return $next($request);
  31. }
  32. // return apiJsonMsg('未登录','400111');
  33. throw new UnauthorizedHttpException('jwt-auth', '未登录');
  34. } catch (TokenExpiredException $exception) {
  35. // 此处捕获到了 token 过期所抛出的 TokenExpiredException 异常,我们在这里需要做的是刷新该用户的 token 并将它添加到响应头中
  36. try {
  37. // 刷新用户的 token
  38. $newToken = $this->auth->refresh();
  39. $request->headers->set('Authorization', 'Bearer ' . $newToken);
  40. // 使用一次性登录以保证此次请求的成功
  41. // \Auth::guard('api')->onceUsingId($this->auth->manager()->getPayloadFactory()->buildClaimsCollection()->toPlainArray()['sub']);
  42. } catch (JWTException $exception) {
  43. // 如果捕获到此异常,即代表 refresh 也过期了,用户无法刷新令牌,需要重新登录。
  44. // return apiJsonMsg('token已失效,请重新登陆','400113');
  45. throw new UnauthorizedHttpException('jwt-auth', 'token已失效,请重新登陆');
  46. }
  47. }
  48. return $next($request)->withHeaders([
  49. 'Authorization' => 'Bearer ' . $newToken,
  50. ]);
  51. }
  52. }