RefreshToken.php 2.4 KB

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