分類  >  WEB開發>PHP >

請教QQ互聯的代碼是如何寫的?

tags:    時間:2013-12-12 13:17:08
請問QQ互聯的代碼是怎麼寫的??
<?php 
  //應用的APPID
  $app_id = "xxxxx";
  //應用的APPKEY
  $app_secret = "xxxxxxx";
  //成功授權后的回調地址
  $my_url = "http://www.abc.com";
 
  //Step1:獲取Authorization Code
  session_start();
  $code = $_REQUEST["code"];
  if(empty($code)) 
  {
     //state參數用於防止CSRF攻擊,成功授權后回調時會原樣帶回
     $_SESSION['state'] = md5(uniqid(rand(), TRUE)); 
     //拼接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']) 
  {
     //拼接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);
     if (strpos($response, "callback") !== false)
     {
        $lpos = strpos($response, "(");
        $rpos = strrpos($response, ")");
        $response  = substr($response, $lpos + 1, $rpos - $lpos -1);
        $msg = json_decode($response);
        if (isset($msg->error))
        {
           echo "<h3>error:</h3>" . $msg->error;
           echo "<h3>msg  :</h3>" . $msg->error_description;
           exit;
        }
     }
 
     //Step3:使用Access Token來獲取用戶的OpenID
     $params = array();
     parse_str($response, $params);
     $graph_url = "https://graph.qq.com/oauth2.0/me?access_token=".$params['access_token'];
     $str  = file_get_contents($graph_url);
     if (strpos($str, "callback") !== false)
     {
        $lpos = strpos($str, "(");
        $rpos = strrpos($str, ")");
        $str  = substr($str, $lpos + 1, $rpos - $lpos -1);
     }
     $user = json_decode($str);
     if (isset($user->error))
     {
        echo "<h3>error:</h3>" . $user->error;
        echo "<h3>msg  :</h3>" . $user->error_description;
        exit;
     }
     echo("Hello " . $user->openid);
  }
  else 
  {
     echo("The state does not match. You may be a victim of CSRF.");
  }
?>

這是在官網弄下來的代碼,
首先在網站上點擊超鏈接,然後跳轉到這個php文件,接下來怎麼做呢,
雲里霧裡,一頭霧水

------解決方案--------------------
QQ互聯?你是要做啥呢,QQ開放平台做開發嗎?
------解決方案--------------------
應該就是QQ開發平台,類似於騰訊微博開發。

推薦閱讀文章

Bookmark the permalink ,來源:互聯網