这篇文章主要讲解一下如何在自己的网站中接入微博登录,废话就不多说了,所有的接入前的条件都和上一篇网站接入QQ登录中的一样,首先还是老规矩,先到微博开放平台,官网http://open.weibo.com/;
然后先使用你的微博账号登录,然后选择网站接入,根据提示创建应用,创建好以后提交审核,等待审核通过后记下App Key和App Secret;
接下来到官网文档里下载PHP SDK,官网下载地址:https://github.com/xiaosier/libweibo.git;下载下来后解压,文件大致如下:
这里只保留 saetv2.ex.class.php 和 weibo_login.png这个图片素材,其他都是官方demo,都删掉!
接下来新建一个config.php文件,代码如下;
?php
define('APP_KEY',''); //填写你的App_Key
define('APP_SECERT','');//填写你的App_Secret
define('REDIRECT_URL',''); //应用回调地址
再创建一个index.php文件,这里用来放置微博登录图标;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>网站接入微博登录</title>
</head>
<body>
<a href="login.php"><img src="weibo_login.png"></a>
</body>
</html>
还需要创建一个login.php,代码如下:
<?php
require_once 'config.php'; //引入配置文件
require_once 'saetv2.ex.class.php';
$o = new SaeTOAuthV2(APP_KEY,APP_SECERT); //实例化SDK授权类
$oauth = $o->getAuthorizeURL(REDIRECT_URL); //
header('location:'.$oauth);
然后在浏览器中打开index.php文件将会跳转到微博授权登录页面;
接下来还需要创建一个callback.php 文件;代码如下:
<?php
require_once 'config.php'; //引入配置文件
require_once 'saetv2.ex.class.php'; //引入官方SDK
$code = $_GET['code']; //获取code
$keys['code'] = $code;
$keys['redirect_uri'] = REDIRECT_URL;
$o = new SaeTOAuthV2(APP_KEY,APP_SECERT); //实例化SDK授权类
$oauth = $o->getAccessToken($type = 'code',$keys);
setcookie('accesstoken',$oauth['access_token '],time()+86400);//将获取到的accesstoken保存到cookie中
header('location:index.php'); 登录成功后跳转到index.php
接下来修改index.php,获取用户信息
<?php
require_once 'config.php'; //引入配置文件
require_once 'saetv2.ex.class.php'; //引入官方SDK
$access_token = $_COOKIE['accesstoken'];//从cookie中获取access_token
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>网站接入微博登录</title>
</head>
<body>
<?php if(!isset($access_token)){ ?>
<a href="login.php"><img src="weibo_login.png"></a>
<?php }else{?>
<a>您已登录</a>
<?php }
//获取用户信息
$o = new SaeTClientV2(APP_KEY,APP_SECERT,$access_token);
$get_uid = $o->get_uid();
$uid = $get_uid['uid'];//获取用户Uid
$usr_info=$o->show_user_by_id($uid); //根据uid获取用户的信息
var_dump($usr_info);//打印出用户信息
?>
</body>
</html>
整个流程差不多就是这个样子,最后就可以将获取到的用户信息进行处理了!