53 lines
1.7 KiB
PHP
53 lines
1.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Middleware;
|
|
|
|
use App\Constants\ErrorCode;
|
|
use Hyperf\Context\Context;
|
|
use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
|
|
use Phper666\JWTAuth\Exception\JWTException;
|
|
use Phper666\JWTAuth\Util\JWTUtil;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use Psr\Http\Message\ServerRequestInterface;
|
|
use Psr\Http\Server\MiddlewareInterface;
|
|
use Psr\Http\Server\RequestHandlerInterface;
|
|
use Phper666\JWTAuth\JWT;
|
|
use Phper666\JWTAuth\Exception\TokenValidException;
|
|
|
|
/**
|
|
* jwt token 校验的中间件,校验场景是否一致
|
|
*/
|
|
class AuthMiddleware implements MiddlewareInterface
|
|
{
|
|
public function __construct(protected HttpResponse $response, protected JWT $jwt)
|
|
{
|
|
}
|
|
|
|
/**
|
|
* @param ServerRequestInterface $request
|
|
* @param RequestHandlerInterface $handler
|
|
* @return ResponseInterface
|
|
* @throws \Psr\SimpleCache\InvalidArgumentException
|
|
* @throws \Throwable
|
|
*/
|
|
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
|
|
{
|
|
$token = $request->getHeaderLine('Authorization') ?? '';
|
|
if ($token === "") {
|
|
throw new JWTException('Missing token', ErrorCode::COMMON_ERROR);
|
|
}
|
|
|
|
$token = JWTUtil::handleToken($token);
|
|
if ($token !== false && $this->jwt->verifyTokenAndScene('default', $token)) {
|
|
// 封装认证用户信息
|
|
$request = $request->withAttribute('AuthUser', JWTUtil::getParserData($request));
|
|
Context::set(ServerRequestInterface::class, $request);
|
|
|
|
return $handler->handle($request);
|
|
}
|
|
|
|
throw new TokenValidException('Token authentication does not pass', ErrorCode::COMMON_ERROR);
|
|
}
|
|
} |