• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

PHP版QQ互联OAuth示例代码分享_PHP

php 搞代码 4年前 (2022-01-25) 21次浏览 已收录 0个评论

由于国内QQ用户的普遍性,所以现在各大网站都尽可能的提供QQ登陆口,下面我们来看看php版,给大家参考下

/** * QQ互联 oauth * @author dyllen * */class Oauth{  //取Authorization Code Url  const PC_CODE_URL = 'https://graph.qq.com/oauth2.0/authorize';     //取Access Token Url  const PC_ACCESS_TOKEN_URL = 'https://graph.qq.com/oauth2.0/token';     //取用户 Open Id Url  const OPEN_ID_URL = 'https://graph.qq.com/oauth2.0/me';     //用户授权之后的回调地址  public $redirectUri = null;     // App Id  public $appid = null;     //App Key  public $appKey = null;     //授权列表  //字符串,多个用逗号隔开  public $scope = null;     //授权code  public $code = null;     //续期access token的凭证  public $refreshToken = null;     //access token  public $accessToken = null;     //access token 有效期,单位秒  public $expiresIn = null;     //state  public $state = null;     public $openid = null;     //construct  public function __construct($config=[])  {    foreach($config as $key => $value) {      $this->$key = $value;    }  }     /**   * 得到获取Code的url   * @throws \InvalidArgumentException   * @return string   */  public function codeUrl()  {    if (!$this->redirectUri) {      throw new \Exception('parameter $redirectUri must be set.');    }    $query = [        'response_type' => 'code',        'client_id' => $this->appid,        'redirect_uri' => $this->redirectUri,        'state' => $this->getState(),        'scope' => $this->scope,    ];       return self::PC_CODE_URL . '?' . http_build_query($query);  }     /**   * 取access token   * @throws Exception   * @return boolean   */  public function getAccessToken()  {    $params = [        'grant_type' => 'authorization_code',        'client_id' => $this->appid,        'client_secret' => $this->appKey,        'code' => $this->code,        'redirect_uri' => $this->redirectUri,    ];       $url = self::PC_ACCESS_TOKEN_URL . '?' . http_build_query($params);    $content = $this->getUrl($url);    parse_str($content, $res);    if ( !isset($res['access_token']) ) {      $this->thrwoError($content);    }       $this->accessToken = $res['access_token'];    $this->expiresIn = $res['expires_in'];    $this->refreshToken = $res['refresh_token'];       return true;  }     /**   * 刷新access token   * @throws Exception   * @return boolean   */  public function refreshToken()  {    $params = [        'grant_type' => 'refresh_token',        'client_id' => $this->appid,        'client_secret' => $this->appKey,        'refresh_token' => $this->refreshToken,    ];       $url = self::PC_ACCESS_TOKEN_URL . '?' . http_build_query($params);    $content = $this->getUrl($url);    parse_str($content, $res);    if ( !isset($res['access_token']) ) {      $this->thrwoError($content);    }       $this->accessToken = $res['access_token'];    $this->expiresIn = $res['expires_in'];    $this->refreshToken = $res['refresh_token'];       return true;  }     /**   * 取用户open id   * @return string   */  public function getOpenid()  {    $params = [        'access_token' => $this->accessToken,    ];       $url = self::OPEN_ID_URL . '?' . http_build_query($params);           $this->openid = $this->parseOpenid( $this->getUrl($url) );         return $this->openid;  }     /**   * get方式取url内容   * @param string $url   * @return mixed   */  public function getUrl($url)  {    $ch = curl_init();    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);    curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);    curl_setopt($ch, CURLOPT_URL, $url);    $response = curl_exec($ch);    curl_close($ch);       return $response;  }     /**   * post方式取url内容   * @param string $url   * @param array $keysArr   * @param number $flag   * @return mixed   */  public function postUrl($url, $keysArr, $flag = 0)  {    $ch = curl_init();    if(! $flag) curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);    curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);    curl_setopt($ch, CURLOPT_POST, TRUE);    curl_setopt($ch, CURLOPT_POSTFIELDS, $keysArr);    curl_setopt($ch, CURLOPT_URL, $url);    $ret = curl_exec($ch);       curl_close($ch);    return $ret;  }        /**   * 取state   * @return string   */  protected function getState()  {    $this->state = md5(uniqid(rand(), true));    //state暂存在缓存里面    //自己定义        //。。。。。。。。。       return $this->state;  }     /**   * 验证state   * @return boolean   */  protected function verifyState()  {    //。。。。。。。  }     /**   * 抛出异常   * @param string $error   * @throws \Exception   */  protected function thrwoError($error)  {    $subError = substr($error, strpos($error, "{"));    $subError = strstr($subError, "}", true) . "}";    $error = json_decode($subError, true);         throw new \Exception($error['error_description'], (int)$error['error']);  }     /**   * 从获取openid接口的返回数据中解析出openid   * @param string $str   * @return string   */  protected function parseOpenid($<mark style="color:transparent">来4源gaodaimacom搞#代%码*网</mark><code>搞代gaodaima码</code>str)  {    $subStr = substr($str, strpos($str, "{"));    $subStr = strstr($subStr, "}", true) . "}";    $strArr = json_decode($subStr, true);    if(!isset($strArr['openid'])) {      $this->thrwoError($str);    }         return $strArr['openid'];  }}

以上所述就是本文的全部内容了,希望大家能够喜欢。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHP版QQ互联OAuth示例代码分享_PHP
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址