TokenMiddleware.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Middleware\Auth;
  4. use App\Model\User;
  5. use Hyperf\Di\Annotation\Inject;
  6. use Phper666\JWTAuth\Exception\TokenValidException;
  7. use Phper666\JWTAuth\JWT;
  8. use Phper666\JWTAuth\Util\JWTUtil;
  9. use Psr\Container\ContainerInterface;
  10. use Psr\Http\Message\ResponseInterface;
  11. use Psr\Http\Server\MiddlewareInterface;
  12. use Psr\Http\Message\ServerRequestInterface;
  13. use Psr\Http\Server\RequestHandlerInterface;
  14. class TokenMiddleware implements MiddlewareInterface
  15. {
  16. /**
  17. * @var ContainerInterface
  18. */
  19. protected $container;
  20. /**
  21. * @Inject()
  22. * @var JWT
  23. */
  24. protected $jwt;
  25. public function __construct(ContainerInterface $container)
  26. {
  27. $this->container = $container;
  28. }
  29. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
  30. {
  31. try {
  32. // 根据具体业务判断逻辑走向,这里假设用户携带的token有效
  33. $token = $request->getHeaderLine('Authorization') ?? '';
  34. if (strlen($token) > 0) {
  35. $token = JWTUtil::handleToken($token);
  36. if ($token == false || !$this->jwt->checkToken($token)) {
  37. throw new TokenValidException(__('api.1005'), 401);
  38. }
  39. $authId = $token->getClaim('authId');
  40. $user = User::where('id', $authId)->where(['enable'=> 'T'])->first();
  41. if(!$user){
  42. throw new TokenValidException(__('api.1029'), 401);
  43. }
  44. }else{
  45. throw new TokenValidException(__('api.1010'), 401);
  46. }
  47. } catch (\Exception $exception){
  48. throw new TokenValidException(__('api.1006'), 401);
  49. }
  50. return $handler->handle($request);
  51. }
  52. }