JwtAuthMiddleware.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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\Facades\JWTAuth;
  7. use Tymon\JWTAuth\Http\Middleware\BaseMiddleware;
  8. class JwtAuthMiddleware
  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. $user = JWTAuth::parseToken()->authenticate();
  21. if (!verifySign($request->get('sign'), $request->all(), md5($user['id']))) {
  22. $error = [
  23. 'message' => '数据验签失败',
  24. 'code' => 401,
  25. ];
  26. return response()->json($error)->setStatusCode(401);
  27. }
  28. } catch (TokenExpiredException $e) {
  29. $error = [
  30. 'message' => 'Token is Expired',
  31. 'code' => 401,
  32. ];
  33. return response()->json($error)->setStatusCode(401);
  34. } catch (TokenInvalidException $e) {
  35. $error = [
  36. 'message' => $e->getMessage(),
  37. 'code' => 401,
  38. ];
  39. return response()->json($error)->setStatusCode(401);
  40. } catch (JWTException $e) {
  41. $error = [
  42. 'message' => $e->getMessage(),
  43. 'code' => 401,
  44. ];
  45. return response()->json($error)->setStatusCode(401);
  46. }
  47. return $next($request);
  48. }
  49. }