ProcurementApiAuth.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Tymon\JWTAuth\Exceptions\JWTException;
  5. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  6. use Tymon\JWTAuth\Exceptions\TokenInvalidException;
  7. use Tymon\JWTAuth\Facades\JWTAuth;
  8. class ProcurementApiAuth
  9. {
  10. /**
  11. * Handle an incoming request.
  12. *
  13. * @param \Illuminate\Http\Request $request
  14. * @param \Closure $next
  15. * @return mixed
  16. */
  17. public function handle($request, Closure $next)
  18. {
  19. try {
  20. if (! $user = JWTAuth::parseToken()->authenticate()) {
  21. return response()->json([
  22. 'code' => 1004,
  23. 'msg' => '用户不存在'
  24. ], 404);
  25. }
  26. return $next($request);
  27. } catch (TokenExpiredException $e) {
  28. return response()->json([
  29. 'code' => 1003,
  30. 'msg' => 'token 过期' ,
  31. ]);
  32. } catch (TokenInvalidException $e) {
  33. return response()->json([
  34. 'code' => 1002,
  35. 'msg' => 'token 无效',
  36. ]);
  37. }catch (JWTException $e) {
  38. return response()->json([
  39. 'code' => 1001,
  40. 'msg' => '缺少token' ,
  41. ]);
  42. }
  43. }
  44. }