设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 创业者 数据 手机
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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

发布时间:2022-06-24 14:22 所属栏目:121 来源:互联网
导读:这篇文章主要介绍了PHP调用QQ互联接口实现QQ登录网站功能,结合实例形式分析php调用QQ互联接口实现QQ登录网站的相关操作技巧,需要的朋友可以参考下。 本文实例讲述了PHP调用QQ互联接口实现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, ")");

      //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."); 。

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读