TokenMiddleware.php 1.9 KB

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