123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- <?php
-
- namespace App\Oauth;
-
- use App\Config\YlyConfig;
- use Exception;
- class YlyOauthClient{
-
- private $clientId;
- private $clientSecret;
- private $tokenUrl;
- private $log;
-
-
- public function __construct(YlyConfig $config)
- {
- $this->clientId = $config->getClientId();
- $this->clientSecret = $config->getClientSecret();
- $this->tokenUrl = $config->getRequestUrl() . '/oauth/oauth';
- $this->log = $config->getLog();
- }
-
-
- public function getToken($code = '')
- {
- $time = time();
- $params = array(
- 'client_id' => $this->clientId,
- 'timestamp' => $time,
- 'sign' => $this->getSign($time),
- 'id' => $this->uuid4(),
- 'scope' => 'all'
- );
- $params['grant_type'] = 'client_credentials';
- if (!empty($code)) {
- $params['code'] = $code;
- $params['grant_type'] = 'authorization_code';
- }
- return $this->send($params);
- }
-
-
- public function refreshToken($refreshToken)
- {
- $time = time();
- $params = array(
- 'client_id' => $this->clientId,
- 'timestamp' => $time,
- 'sign' => $this->getSign($time),
- 'id' => $this->uuid4(),
- 'scope' => 'all',
- 'grant_type' => 'refresh_token',
- 'refresh_token' => $refreshToken,
- );
- return $this->send($params);
- }
-
-
- public function getSign($timestamp)
- {
- return md5(
- $this->clientId.
- $timestamp.
- $this->clientSecret
- );
- }
-
-
- public function uuid4(){
- mt_srand((double)microtime() * 10000);
- $charid = strtolower(md5(uniqid(rand(), true)));
- $hyphen = '-';
- $uuidV4 =
- substr($charid, 0, 8) . $hyphen .
- substr($charid, 8, 4) . $hyphen .
- substr($charid, 12, 4) . $hyphen .
- substr($charid, 16, 4) . $hyphen .
- substr($charid, 20, 12);
- return $uuidV4;
- }
-
-
- public function send($data)
- {
- $requestInfo = http_build_query($data);
- $log = $this->log;
- if ($log != null) {
- $log->info("request data: " . $requestInfo);
- }
- $curl = curl_init(); // 启动一个CURL会话
- curl_setopt($curl, CURLOPT_URL, $this->tokenUrl); // 要访问的地址
- curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检测
- curl_setopt($curl, CURLOPT_HTTPHEADER, array(
- 'Expect:'
- )); // 解决数据包大不能提交
- curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
- curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer
- curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求
- curl_setopt($curl, CURLOPT_POSTFIELDS, $requestInfo); // Post提交的数据包
- curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循
- curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容
- curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回
- $requestResponse = curl_exec($curl); // 执行操作
- $response = json_decode($requestResponse);
- if (curl_errno($curl)) {
- if ($log != null) {
- $log->error("error: " . curl_error($curl));
- }
- throw new Exception(curl_error($curl));
- }
- if (is_null($response)) {
- throw new Exception("illegal response :" . $requestResponse);
- }
- if ($response->error != 0 && $response->error_description != 'success') {
- throw new Exception(json_encode($response));
- }
- if ($this->log != null) {
- $this->log->info("response: " . json_encode($response));
- }
- curl_close($curl); // 关键CURL会话
- return $response->body; // 返回数据
- }
-
-
- }
|