TokenMiddleware.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Middleware\Auth;
  4. use App\Model\User;
  5. use Phper666\JWTAuth\Exception\TokenValidException;
  6. use Phper666\JWTAuth\JWT;
  7. use Psr\Container\ContainerInterface;
  8. use Psr\Http\Message\ResponseInterface;
  9. use Psr\Http\Server\MiddlewareInterface;
  10. use Psr\Http\Message\ServerRequestInterface;
  11. use Psr\Http\Server\RequestHandlerInterface;
  12. class TokenMiddleware implements MiddlewareInterface
  13. {
  14. /**
  15. * @var ContainerInterface
  16. */
  17. protected $container;
  18. /**
  19. * @Inject()
  20. * @var JWT
  21. */
  22. protected $jwt;
  23. public function __construct(ContainerInterface $container)
  24. {
  25. $this->container = $container;
  26. }
  27. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
  28. {
  29. try {
  30. // 获取当前TOKEN
  31. $token = $this->jwt->getToken();
  32. var_dump($token);
  33. // 验证TOKEN有效性
  34. if($this->jwt->checkToken()){
  35. $authId = $token->getClaim('authId');
  36. $user = User::where('id', $authId)->where(['enable'=> 'T'])->first();
  37. var_dump($user);
  38. if(!$user){
  39. throw new TokenValidException('Token未验证通过', 401);
  40. }
  41. }
  42. } catch (\Exception $exception){
  43. }
  44. return $handler->handle($request);
  45. }
  46. }