1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- <?php
- declare(strict_types=1);
- namespace App\Middleware\Auth;
- use Hyperf\Di\Annotation\Inject;
- use Hyperf\HttpServer\Contract\RequestInterface;
- use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
- use Psr\Container\ContainerInterface;
- use Psr\Http\Message\ResponseInterface;
- use Psr\Http\Message\ServerRequestInterface;
- use Psr\Http\Server\MiddlewareInterface;
- use Psr\Http\Server\RequestHandlerInterface;
- use Hyperf\Context\Context;
- use App\JsonRpc\WebsiteServiceInterface;
- use Phper666\JWTAuth\JWT;
- class FooMiddleware implements MiddlewareInterface
- {
- protected ContainerInterface $container;
- protected RequestInterface $request;
- protected HttpResponse $response;
- protected JWT $JWT;
- /**
- * @var WebsiteServiceInterface
- */
- #[Inject]
- private $websiteServiceClient;
- public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request,Jwt $JWT)
- {
- $this->container = $container;
- $this->response = $response;
- $this->request = $request;
- $this->JWT = $JWT;
- }
- public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
- {
- $header = $request->getHeaders();
- try {
- if($header && isset($header['token']) && $header['token'][0]!='null' && $header['token'][0]!='' && isset($header['token'][0])){
- $ver = $this->JWT->getClaimsByToken($header['token'][0]);
- $tokenTime = $this->JWT->getTokenDynamicCacheTime($header['token'][0]);
-
- if($tokenTime==0){
- return $this->response->raw(json_encode([
- 'code' => -1,
- 'data' => [],
- 'message' => 'token无效,请重新登录'
- ]));
- }
- if($header['userurl'] && $header['userurl'][0]){
- $origin = $header['userurl'][0];
- $data = [
- 'website_url'=>$origin
- ];
- $result = $this->websiteServiceClient->getWebsiteId($data);
- if(!isset($result['data']['id']) || !$result['data']['id']){
- return $this->response->raw(json_encode([
- 'code' => -1,
- 'data' => [],
- 'message' => '网站不存在...'
- ]));
- }
- Context::set("SiteId",$result['data']['id']);
- }
- Context::set("UserId",$ver['uid']);
- Context::set("TypeId",$ver['type_id']);
-
- if ($ver) {
- return $handler->handle($request);
- }
- }
- return $this->response->raw(json_encode([
- 'code' => -1,
- 'data' => [],
- 'message' => 'token无效,请重新登录'
- ]));
- } catch (\Exception $e) {
- return $this->response->raw(json_encode([
- 'code' => $e->getCode(),
- 'data' => [],
- 'message' => $e->getMessage()
- ]));
- }
- }
- }
|