Files
huangjingfen/pro_v3.5.1/crmeb/services/AccessTokenServeService.php

168 lines
4.7 KiB
PHP
Raw Normal View History

2026-03-07 22:29:07 +08:00
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace crmeb\services;
use crmeb\exceptions\ApiException;
use think\facade\Log;
/**
* Class AccessTokenServeService
* @package crmeb\services
*/
class AccessTokenServeService extends HttpService
{
/**
* 配置
* @var string
*/
protected string $account;
/**
* @var string
*/
protected string $secret;
/**
* @var Cache|null
*/
protected $cache;
/**
* @var string
*/
protected string $cacheTokenPrefix = "_crmeb_plat";
/**
* @var string
*/
protected string $apiHost = 'http://sms.crmeb.net/api/';
/**
* 登录接口
*/
const USER_LOGIN = "v2/user/login";
/**
* AccessTokenServeService constructor.
* @param string $account
* @param string $secret
* @param 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;
}
/**
* 获取配置
* @return array
*/
public function getConfig(): array
{
return [
'access_key' => $this->account,
'secret_key' => $this->secret
];
}
/**
* 获取缓存token
* @return mixed
*/
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'], 300);
$cacheToken = $getToken['access_token'];
}
return $cacheToken;
}
/**
* 从服务器获取token
* @return mixed
*/
public function getTokenFromServer()
{
$params = [
'access_key' => $this->account,
'secret_key' => $this->secret,
];
if (!$this->account || !$this->secret) {
throw new ApiException('请先登录一号通平台!');
}
$response = $this->postRequest($this->get(self::USER_LOGIN), $params);
$response = json_decode($response, true);
if (!$response) {
throw new ApiException('获取token失败');
}
if ($response['status'] === 200) {
return $response['data'];
} else {
throw new ApiException($response['msg']);
}
}
/**
* 请求
* @param string $url
* @param array $data
* @param string $method
* @param bool $isHeader
* @param array $header
* @return array|mixed
*/
public function httpRequest(string $url, array $data = [], string $method = 'POST', bool $isHeader = true, array $header = [])
{
if ($isHeader) {
$accessToken = $this->getToken();
if (!$accessToken) {
throw new ApiException('配置已更改或token已失效');
}
$header = array_merge($header, ['Authorization:Bearer-' . $accessToken]);
}
Log::info('请求接口:' . $url . ' 请求参数:' . json_encode($data, JSON_UNESCAPED_UNICODE));
$res = $this->request($this->get($url), $method, $data, $header);
if (!$res) {
throw new ApiException('平台错误:发生异常,请稍后重试');
}
$result = json_decode($res, true) ?: false;
if (!isset($result['status']) || $result['status'] != 200) {
throw new ApiException(isset($result['msg']) ? '平台错误:' . $result['msg'] : '平台错误:发生异常,请稍后重试');
}
Log::info('接口返回:' . json_encode($result, JSON_UNESCAPED_UNICODE));
return $result['data'] ?? [];
}
/**
* @param string $apiUrl
* @return string
*/
public function get(string $apiUrl = '')
{
return $this->apiHost . $apiUrl;
}
}