1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- <?php
- declare(strict_types=1);
- namespace App\Middleware\Auth;
- use Hyperf\HttpServer\Contract\RequestInterface;
- use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
- use Psr\Container\ContainerInterface;
- use Psr\Http\Message\ResponseInterface;
- use Psr\Http\Message\ServerRequestInterface;
- use Psr\Http\Server\MiddlewareInterface;
- use Psr\Http\Server\RequestHandlerInterface;
- use \Phper666\JWTAuth\JWT;
- class FooMiddleware implements MiddlewareInterface
- {
- protected ContainerInterface $container;
- protected RequestInterface $request;
- protected HttpResponse $response;
- protected JWT $JWT;
- public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request,Jwt $JWT)
- {
- $this->container = $container;
- $this->response = $response;
- $this->request = $request;
- $this->JWT = $JWT;
- }
- public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
- {
- $header = $request->getHeaders();
- $ver = $this->JWT->verifyTokenAndScene('default', $header['token'][0]);
- // 根据具体业务判断逻辑走向,这里假设用户携带的token有效
- $isValidToken = $ver;
- if ($isValidToken) {
- return $handler->handle($request);
- }
- return $this->response->json(
- [
- 'code' => -1,
- 'data' => [],
- 'message' => '中间件验证token无效,阻止继续向下执行',
- ]
- );
- }
- }
|