WebApi.php 979 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Helpers\ResponseEnum;
  4. use App\Helpers\WebApiResponse;
  5. use Closure;
  6. use Illuminate\Http\Request;
  7. class WebApi
  8. {
  9. /**
  10. * Handle an incoming request.
  11. *
  12. * @return mixed
  13. */
  14. use WebApiResponse;
  15. public function handle(Request $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->failed([400200, 'Your key is null!']);
  22. }
  23. $nodeAuth = $node->auth ?? null;
  24. if (! isset($nodeAuth) || $key !== $nodeAuth->key) { // key不存在/不匹配
  25. return $this->failed(ResponseEnum::CLIENT_PARAMETER_ERROR);
  26. }
  27. if (abs($time - time()) >= 300) { // 时差超过5分钟
  28. return $this->failed(ResponseEnum::CLIENT_HTTP_UNSYNCHRONIZE_TIMER);
  29. }
  30. return $next($request);
  31. }
  32. }