加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_宿迁站长网 (https://www.0527zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP 调用QQ互联接口实现QQ登录网站功能案例

发布时间:2022-10-27 10:52:21 所属栏目:PHP教程 来源:
导读:  这篇文章主要介绍了PHP调用QQ互联接口实现QQ登录网站功能,结合实例形式分析php调用QQ互联接口实现QQ登录网站的相关操作技巧,需要的朋友可以参考下。

  本文实例讲述了PHP调用QQ互联接口实现QQ登录网站功能
  这篇文章主要介绍了PHP调用QQ互联接口实现QQ登录网站功能,结合实例形式分析php调用QQ互联接口实现QQ登录网站的相关操作技巧,需要的朋友可以参考下。
 
  本文实例讲述了PHP调用QQ互联接口实现QQ登录网站功能,分享给大家供大家参考,具体如下:调用QQ登录接口,首先要到QQ互联完善开发者认证信息,并通过审核,然后创建一个网站应用,获得APP ID和APP Key,通过审核后即可调用基本接口get_user_info(获得用户信息),实现QQ登录网站功能。
 
  PHP调用QQ互联接口实现QQ登录网站功能示例
 
  废话不多,上示例代码(QQ登录李维山博客):
 
  <?php
    header("Content-Type: text/html;charset=utf-8");
    //应用APP ID
    $app_id = "101486017";
    //应用APP Key
    $app_secret = "13a1811780f29d7a5b64e598c38a4494";
 
      //拼接URL
      $dialog_url = "https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=".$app_id."&redirect_uri=".urlencode($my_url)."&state=".$_SESSION['state'];
      echo("<script> top.location.href='".$dialog_url."'</script>");
    }
    //Step2:通过Authorization Code获取Access Token
    if($_REQUEST['state'] == $_SESSION['state'] || 1) {
      //拼接URL
      $token_url = "https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&"."client_id=".$app_id."&redirect_uri=".urlencode($my_url)."&client_secret=".$app_secret."&code=".$code;
      $response = file_get_contents($token_url);
      //如果用户临时改变主意取消登录,返回true!==false,否则执行step3  
      if (strpos($response, "callback") !== false) {
        $lpos = strpos($response, "(");
        $rpos = strrpos($response, ")");
PHP调用QQ互联接口实现QQ登录网站功能案例
      //Step4:使用openid和access_token获取用户信息
      $user_data_url = "https://graph.qq.com/user/get_user_info?access_token={$params['access_token']}&oauth_consumer_key={$app_id}&openid={$user->openid}&format=json";
      $user_data = file_get_contents($user_data_url);//获取到的用户信息
      //以下为授权成功后的自定义操作
      if($user_data){
        // ......
        echo("<script> top.location.href='http://www.phpfensi.com'</script>");
      }else{
        echo '未知错误';
      }
    }else{
      echo("The state does not match. You may be a victim of CSRF."); 。
 

(编辑:云计算网_宿迁站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!