| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- <?php
- declare(strict_types=1);
- namespace App\Middleware\Auth;
- use App\Controller\Resource\ApiResource;
- use App\Model\User;
- use Hyperf\Di\Annotation\Inject;
- use Phper666\JWTAuth\Exception\TokenValidException;
- use Phper666\JWTAuth\JWT;
- use Phper666\JWTAuth\Util\JWTUtil;
- use Psr\Container\ContainerInterface;
- use Psr\Http\Message\ResponseInterface;
- use Psr\Http\Server\MiddlewareInterface;
- use Psr\Http\Message\ServerRequestInterface;
- use Psr\Http\Server\RequestHandlerInterface;
- class TokenMiddleware implements MiddlewareInterface
- {
- /**
- * @var ContainerInterface
- */
- protected $container;
- /**
- * @Inject()
- * @var JWT
- */
- protected $jwt;
- public function __construct(ContainerInterface $container)
- {
- $this->container = $container;
- }
- public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
- {
- try {
- // 根据具体业务判断逻辑走向,这里假设用户携带的token有效
- $token = $request->getHeaderLine('Authorization') ?? '';
- if (strlen($token) > 0) {
- $token = JWTUtil::handleToken($token);
- if ($token == false || !$this->jwt->checkToken($token)) {
- throw new TokenValidException(1005, 1002);
- }
- $authId = $token->getClaim('authId');
- $user = User::where('id', $authId)->where(['enable'=> 'T'])->first();
- if(!$user){
- throw new TokenValidException(1029, 1002);
- }
- }else{
- //return ApiResource::failed(1010);
- throw new TokenValidException(1010, 1002);
- }
- } catch (\Exception $exception){
- throw new TokenValidException(1006, 1002);
- }
- return $handler->handle($request);
- }
- }
|