123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- <?php
- /**
- * @author: liaofei<136327134@qq.com>
- * @day: 2020/9/12
- */
- namespace crmeb\services;
- use crmeb\exceptions\ApiException;
- use think\exception\ValidateException;
- class AccessTokenServeService extends HttpService
- {
- /**
- * 配置
- * @var string
- */
- protected $account;
- /**
- * @var string
- */
- protected $secret;
- /**
- * @var Cache|null
- */
- protected $cache;
- /**
- * @var string
- */
- protected $accessToken;
- /**
- * @var string
- */
- protected $cacheTokenPrefix = "_crmeb_plat";
- /**
- * @var string
- */
- protected $apiHost = 'http://sms.crmeb.net/api/';
- const USER_LOGIN = "user/login";
- /**
- * AccessTokenServeService constructor.
- * @param string $account
- * @param string $secret
- * @param Cache|null $cache
- */
- public function __construct(string $account, string $secret, $cache = null)
- {
- if (!$cache) {
- /** @var CacheService $cache */
- $cache = app()->make(CacheService::class);
- }
- $this->account = $account;
- $this->secret = $secret;
- $this->cache = $cache;
- }
- /**
- * 获取缓存token
- * @return mixed
- * @throws \Psr\SimpleCache\InvalidArgumentException
- */
- public function getToken()
- {
- $accessTokenKey = md5($this->account . '_' . $this->secret . $this->cacheTokenPrefix);
- $cacheToken = $this->cache->get($accessTokenKey);
- if (!$cacheToken) {
- $getToken = $this->getTokenFromServer();
- $this->cache->set($accessTokenKey, $getToken['access_token'], $getToken['expires_in'] - time() - 300);
- $cacheToken = $getToken['access_token'];
- }
- $this->accessToken = $cacheToken;
- return $cacheToken;
- }
- /**
- * 销毁token
- * @return bool
- * @throws \Psr\SimpleCache\InvalidArgumentException
- */
- public function destroyToken()
- {
- $accessTokenKey = md5($this->account . '_' . $this->secret . $this->cacheTokenPrefix);
- return $this->cache->delete($accessTokenKey);
- }
- /**
- * 从服务器获取token
- * @return mixed
- */
- public function getTokenFromServer()
- {
- $params = [
- 'account' => $this->account,
- 'secret' => md5($this->account . md5($this->secret)),
- ];
- $response = $this->postRequest($this->get(self::USER_LOGIN), $params);
- $response = json_decode($response, true);
- if (!$response) {
- throw new ValidateException('获取token失败');
- }
- if ($response['status'] === 200) {
- return $response['data'];
- } else {
- exception($response['msg']);
- }
- }
- /**
- * 请求
- * @param string $url
- * @param array $data
- * @param string $method
- * @param bool $isHeader
- * @return array|mixed
- */
- public function httpRequest(string $url, array $data = [], string $method = 'POST', bool $isHeader = true)
- {
- $header = [];
- if ($isHeader) {
- $this->getToken();
- if (!$this->accessToken) {
- throw new ValidateException('配置已更改或token已失效');
- }
- $header = ['Authorization:Bearer-' . $this->accessToken];
- }
- try {
- $res = $this->request($this->get($url), $method, $data, $header);
- if (!$res) {
- exception('发生异常,请稍后重试');
- }
- $result = json_decode($res, true) ?: false;
- if (!isset($result['status']) || $result['status'] != 200) {
- exception($result['msg'] ?? '发生异常,请稍后重试');
- }
- return $result['data'] ?? [];
- } catch (\Throwable $e) {
- exception($e->getMessage());
- }
- }
- /**
- * @param string $apiUrl
- * @return string
- */
- public function get(string $apiUrl = '')
- {
- return $this->apiHost . $apiUrl;
- }
- }
|