ApiSign.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Middleware;
  4. use App\Utils\AppResult;
  5. use App\Utils\Control\AuthUser;
  6. use Hyperf\HttpServer\Contract\RequestInterface;
  7. use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
  8. use Psr\Container\ContainerInterface;
  9. use Psr\Http\Message\ResponseInterface;
  10. use Psr\Http\Message\ServerRequestInterface;
  11. use Psr\Http\Server\MiddlewareInterface;
  12. use Psr\Http\Server\RequestHandlerInterface;
  13. class ApiSign implements MiddlewareInterface
  14. {
  15. /**
  16. * @var ContainerInterface
  17. */
  18. protected $container;
  19. /**
  20. * @var RequestInterface
  21. */
  22. protected $request;
  23. /**
  24. * @var HttpResponse
  25. */
  26. protected $response;
  27. public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request)
  28. {
  29. $this->container = $container;
  30. $this->response = $response;
  31. $this->request = $request;
  32. }
  33. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
  34. {
  35. //验证登录
  36. if (!AuthUser::getInstance()->check()) {
  37. return AppResult::response_fast(401,'未登录,令牌失效,请稍后重试!');
  38. }
  39. // 根据具体业务判断逻辑走向
  40. return $handler->handle($request);
  41. }
  42. }