


[php]
function login($code){
$APP_ID="XX";
$APP_KEY="XX";
$redirect_uri="成功授权后的回调地址(同上)"
$url = "https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&client_id=$APP_ID&client_secret=$APP_KEY";
$url .= "&code=$code&redirect_uri=$redirect_uri";//给URL赋值
$html = file_get_contents ( $url );//GET 访问,然后会返回一个我们下一步GET访问所需要的值,access_token,我们要用它来获取用户的OpenID
$url = "https://graph.qq.com/oauth2.0/me?access_token=" . getSubstr ( $html, 'access_token=', '&' );
$html = file_get_contents ( $url );//GET访问 获取OpenID
$userJson = json_decode ( getSubstr ( $html, 'callback( ', ')' ) );
$userJson->openid;
//这之后就是用openid在数据库里面搜索有没有相对应的账号,openid是用户的唯一标识,QQ它不会返回用户的QQ账号,而且不同的应用会有不同的openid,开始的时候我想错了,一直想着没QQ账号怎么来验证这个登陆的人是谁
return;
}
function getSubstr($str, $leftStr, $rightStr) { // 取出中间文本
$left = strpos ( $str, $leftStr );
// echo '左边:'.$left;
$right = strpos ( $str, $rightStr, $left );
// echo '
右边:'.$right;
if ($left < 0 or $right < $left)
return '';
return substr ( $str, $left + strlen ( $leftStr ), $right - $left - strlen ( $leftStr ) );
}
[/php]
文章评论