WebApi.php 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Illuminate\Http\JsonResponse;
  5. use Response;
  6. class WebApi
  7. {
  8. /**
  9. * Handle an incoming request.
  10. *
  11. * @param $request
  12. * @param Closure $next
  13. * @return mixed
  14. */
  15. public function handle($request, Closure $next)
  16. {
  17. $node = $request->node;
  18. $key = $request->header('key');
  19. $time = $request->header('timestamp');
  20. if (! isset($key)) {// 未提供 key
  21. return $this->returnData('Your key is null!', 400);
  22. }
  23. $nodeAuth = $node->auth ?? null;
  24. if (! isset($nodeAuth) || $key !== $nodeAuth->key) {// key不存在/不匹配
  25. return $this->returnData('Token is invalid!');
  26. }
  27. if (abs($time - time()) >= 300) {// 时差超过5分钟
  28. return $this->returnData('Please resynchronize the server time!');
  29. }
  30. return $next($request);
  31. }
  32. // 返回数据
  33. private function returnData(string $message, int $code = 401): JsonResponse
  34. {
  35. return Response::json(['status' => 'fail', 'code' => $code, 'message' => $message]);
  36. }
  37. }