关于微博开放平台Oauth2.0接入网站应用
2014-08-01 20:52
387 查看
关于什么是微博开放平台及微博开放平台能做什么,咱就不做搜索引擎的搬运工了
这里直接给个链接介绍:微博开放平台
本文只是抛砖引玉,讲讲微博开放平台的基本用法,适合没接触过开放平台的朋友入门学习,老鸟就略过啦~
举例(新浪)微博开放平台:http://open.weibo.com/ (这里是官网)
先来看看关于微博开放平的台网站接入:
什么是网站接入?
举几个例子,比如我们经常会看到各大网站可以直接使用QQ,微博,微信等账号直接登录、各种文章、游戏、页面的一键分享、同步到QQ空间、微博等社交工具的实时动态等,这些都是开放平台网站接入的功能。
好了,话不多说了,直接进入主题
1、首先得先注册个新浪微博的账号,然后登陆开放平台
http://open.weibo.com/
然后在 管理中心->我的网站->添加新网站 填写下关于自己网站的一些基本信息,然后复制下面的<meta>标签里的内容到自己的网站首页就可以完成认证了。
然后记录下自己的WB_AKEY和WB_SKEY(这个很重要),涉及到安全,我这里就不截图了。
在我的网站里就可以看到我们刚填写的网站应用了
2、接着我们就可以在官网上下载相关的SDK开发工具包了,这里包括 Java , PHP, Flash, iOS, WP7, Android及 Python等语言。
下载链接:http://open.weibo.com/wiki/SDK
我个人用的是PHP,就说这个啦,因为SDK放在谷歌上,可能访问有点慢。
http://code.google.com/p/libweibo/downloads/list
这里要下载上图红框里的任一一个压缩包,包含新版接口及OAuth2.0。
这是压缩包的内容:
分别介绍下各文件:
callback.php 回调,简单说就是认证,获取access_token
config.php 参数配置文件,包含APP key、APP secret和回调页面地址的参数
index.php 首页
saetv2.ex.class.php 新浪微博的操作类和认证类,就是SDK,里面有许多注释可以当成API来使用
weibolist.php 我们要实现的功能都在这一个php页面中
文件执行顺序为: index.php->callback.php—>weibolist.php
首先在index.php请求授权,跳转callback.php后代表授权成功,然后进入weibolist.php进行对应操作。
在weibolist.php会实例化一个"微博操作类",然后就可以进行一系列的方法调用。
3、具体代码实现
先修改config.php里面的配置信息,填入我们刚记录的WB_AKEY和WB_SKEY,这里是要特别注意的是WB_CALLBACK_URL回调页面地址的填写,HTTP不能省略,需填写完整的URL
然后来到index.php(这里要吐槽下新浪写这个Demo的工作人员,现在PHP新版已经不支持<?=?>这种写法的输入格式了)
举个例子:
大家对应的修改下原代码,改成echo输出就好了。
在微博开放平台没改版之前,记得里面的Demo还有个$_SERVER['SCRIPT_URI']这也是不能用的,要对应修改。
然后就可以把文件上传到自己的公网服务器了,本来是可以在本地做测试的,开放平台改版后,为控制环境,要求严格了些。
打开我们的首页index.php,点击用微博账号登陆,登陆成功会出现如下文字。
授权完成,进入你的微博列表页面
点击进入weibolist.php页面,我们就可以看到对应微博账号所看到的对应微博信息了。
分析下weibolist.php的代码:
其实一目了然了,引入配置文件,类库,实例化出对象,传参,调用方法,返回值。
比如:
$c = new SaeTClientV2( WB_AKEY , WB_SKEY , $_SESSION['token']['access_token'] );
Saetv2.ex.class.php中有两个类:微博操作类SaeTClientV2,微博认证类SaeTOAuthV2。
操作类的实例化需要的参数 ( $akey, $skey, $access_token),而 access_token就是需要从认证类获得的,只有我们获得了用户的access_token,才能对用户进行操作。
callback.php中:
在callback.php中获得的access_token 存在了session中,在创建微博操作类的时候就可以把它拿出来用。
$ms = $c->home_timeline();
打开类库文件查找home_timeline方法,获取当前登录用户及其所关注用户的最新微博消息,API已经写的很清楚了,大家有时间多去可以去读读源码。
很简单吧?找几个方法来试试吧。
自己写个表单发个微博试试
打开得到如下数据:
然后我们就可以根据UID去获取更多的信息,比如用户名,基础资料等。
内容有点多,我就不一一去演示了
有兴趣的朋友可以多看看saetv2.ex.class.php文件
官网提供的API:http://open.weibo.com/wiki/%E5%BE%AE%E5%8D%9AAPI
好啦,就此结束吧,毕竟只是作为入门介绍
有时间再写篇关于微博开放平台站内应用的入门介绍~See you
这里直接给个链接介绍:微博开放平台
本文只是抛砖引玉,讲讲微博开放平台的基本用法,适合没接触过开放平台的朋友入门学习,老鸟就略过啦~
举例(新浪)微博开放平台:http://open.weibo.com/ (这里是官网)
先来看看关于微博开放平的台网站接入:
什么是网站接入?
举几个例子,比如我们经常会看到各大网站可以直接使用QQ,微博,微信等账号直接登录、各种文章、游戏、页面的一键分享、同步到QQ空间、微博等社交工具的实时动态等,这些都是开放平台网站接入的功能。
好了,话不多说了,直接进入主题
1、首先得先注册个新浪微博的账号,然后登陆开放平台
http://open.weibo.com/
然后在 管理中心->我的网站->添加新网站 填写下关于自己网站的一些基本信息,然后复制下面的<meta>标签里的内容到自己的网站首页就可以完成认证了。
然后记录下自己的WB_AKEY和WB_SKEY(这个很重要),涉及到安全,我这里就不截图了。
在我的网站里就可以看到我们刚填写的网站应用了
2、接着我们就可以在官网上下载相关的SDK开发工具包了,这里包括 Java , PHP, Flash, iOS, WP7, Android及 Python等语言。
下载链接:http://open.weibo.com/wiki/SDK
我个人用的是PHP,就说这个啦,因为SDK放在谷歌上,可能访问有点慢。
http://code.google.com/p/libweibo/downloads/list
这里要下载上图红框里的任一一个压缩包,包含新版接口及OAuth2.0。
这是压缩包的内容:
分别介绍下各文件:
callback.php 回调,简单说就是认证,获取access_token
config.php 参数配置文件,包含APP key、APP secret和回调页面地址的参数
index.php 首页
saetv2.ex.class.php 新浪微博的操作类和认证类,就是SDK,里面有许多注释可以当成API来使用
weibolist.php 我们要实现的功能都在这一个php页面中
文件执行顺序为: index.php->callback.php—>weibolist.php
首先在index.php请求授权,跳转callback.php后代表授权成功,然后进入weibolist.php进行对应操作。
在weibolist.php会实例化一个"微博操作类",然后就可以进行一系列的方法调用。
3、具体代码实现
先修改config.php里面的配置信息,填入我们刚记录的WB_AKEY和WB_SKEY,这里是要特别注意的是WB_CALLBACK_URL回调页面地址的填写,HTTP不能省略,需填写完整的URL
<?php header('Content-Type: text/html; charset=UTF-8'); define( "WB_AKEY" , 'xxxxxxxxxx' ); define( "WB_SKEY" , 'xxxxxxxxxxxxxxxxxxxxxxxxx' ); define( "WB_CALLBACK_URL" , 'http://xxxxxxxxxxxx/callback.php' );
然后来到index.php(这里要吐槽下新浪写这个Demo的工作人员,现在PHP新版已经不支持<?=?>这种写法的输入格式了)
举个例子:
<a href="<?=$code_url?>"><img src="weibo_login.png" title="点击进入授权页面" alt="点击进入授权页面" border="0" />
大家对应的修改下原代码,改成echo输出就好了。
在微博开放平台没改版之前,记得里面的Demo还有个$_SERVER['SCRIPT_URI']这也是不能用的,要对应修改。
<a href="<?php echo $code_url?>"><img src="weibo_login.png" title="点击进入授权页面" alt="点击进入授权页面" border="0" /></a>
然后就可以把文件上传到自己的公网服务器了,本来是可以在本地做测试的,开放平台改版后,为控制环境,要求严格了些。
打开我们的首页index.php,点击用微博账号登陆,登陆成功会出现如下文字。
授权完成,进入你的微博列表页面
点击进入weibolist.php页面,我们就可以看到对应微博账号所看到的对应微博信息了。
分析下weibolist.php的代码:
<?php session_start(); include_once( 'config.php' ); include_once( 'saetv2.ex.class.php' ); $c = new SaeTClientV2( WB_AKEY , WB_SKEY , $_SESSION['token']['access_token'] ); $ms = $c->home_timeline(); // done $uid_get = $c->get_uid(); $uid = $uid_get['uid']; $user_message = $c->show_user_by_id( $uid);//根据ID获取用户等基本信息 ?>
其实一目了然了,引入配置文件,类库,实例化出对象,传参,调用方法,返回值。
比如:
$c = new SaeTClientV2( WB_AKEY , WB_SKEY , $_SESSION['token']['access_token'] );
Saetv2.ex.class.php中有两个类:微博操作类SaeTClientV2,微博认证类SaeTOAuthV2。
操作类的实例化需要的参数 ( $akey, $skey, $access_token),而 access_token就是需要从认证类获得的,只有我们获得了用户的access_token,才能对用户进行操作。
callback.php中:
setcookie( 'weibojs_'.$o->client_id, http_build_query($token) );
在callback.php中获得的access_token 存在了session中,在创建微博操作类的时候就可以把它拿出来用。
$ms = $c->home_timeline();
打开类库文件查找home_timeline方法,获取当前登录用户及其所关注用户的最新微博消息,API已经写的很清楚了,大家有时间多去可以去读读源码。
/** * 获取当前登录用户及其所关注用户的最新微博消息。 * * 获取当前登录用户及其所关注用户的最新微博消息。和用户登录 http://weibo.com 后在“我的首页”中看到的内容相同。同friends_timeline() * <br />对应API:{@link http://open.weibo.com/wiki/2/statuses/home_timeline statuses/home_timeline} * * @access public * @param int $page 指定返回结果的页码。根据当前登录用户所关注的用户数及这些被关注用户发表的微博数,翻页功能最多能查看的总记录数会有所不同,通常最多能查看1000条左右。默认值1。可选。 * @param int $count 每次返回的记录数。缺省值50,最大值200。可选。 * @param int $since_id 若指定此参数,则只返回ID比since_id大的微博消息(即比since_id发表时间晚的微博消息)。可选。 * @param int $max_id 若指定此参数,则返回ID小于或等于max_id的微博消息。可选。 * @param int $base_app 是否只获取当前应用的数据。0为否(所有数据),1为是(仅当前应用),默认为0。 * @param int $feature 过滤类型ID,0:全部、1:原创、2:图片、3:视频、4:音乐,默认为0。 * @return array */ function home_timeline( $page = 1, $count = 50, $since_id = 0, $max_id = 0, $base_app = 0, $feature = 0 ) { $params = array(); if ($since_id) { $this->id_format($since_id); $params['since_id'] = $since_id; } if ($max_id) { $this->id_format($max_id); $params['max_id'] = $max_id; } $params['count'] = intval($count); $params['page'] = intval($page); $params['base_app'] = intval($base_app); $params['feature'] = intval($feature); return $this->oauth->get('statuses/home_timeline', $params); }
很简单吧?找几个方法来试试吧。
自己写个表单发个微博试试
<?php session_start(); include_once( 'config.php' ); include_once( 'saetv2.ex.class.php' ); $c = new SaeTClientV2( WB_AKEY , WB_SKEY , $_SESSION['token']['access_token'] );
$ms = $c->home_timeline(); // done $uid_get = $c->get_uid(); $uid = $uid_get['uid']; $user_message = $c->show_user_by_id( $uid);//根据ID获取用户等基本信息 if($_POST['content']){ $c->update($_POST['content']); }else{ } ?> <form action="" method="post"> <input type="text" name="content"/> <input type="submit" value="发布微博"/> </form>
哈哈,是不是很简单呢? 再试试获取关注人ID
/** * 获取用户的双向关注uid列表 * * 对应API:{@link http://open.weibo.com/wiki/2/friendships/friends/bilateral/ids friendships/friends/bilateral/ids} * * @param int $uid 需要获取双向关注列表的用户UID。 * @param int $count 单页返回的记录条数,默认为50。 * @param int $page 返回结果的页码,默认为1。 * @param int $sort 排序类型,0:按关注时间最近排序,默认为0。 * @return array **/ function bilateral_ids( $uid, $page = 1, $count = 50, $sort = 0) { $params = array(); $params['uid'] = $uid; $params['count'] = $count; $params['page'] = $page; $params['sort'] = $sort; return $this->oauth->get( 'friendships/friends/bilateral/ids', $params ); }
<?php session_start(); include_once( 'config.php' ); include_once( 'saetv2.ex.class.php' ); $c = new SaeTClientV2( WB_AKEY , WB_SKEY , $_SESSION['token']['access_token'] );
$ms = $c->home_timeline(); // done
$uid_get = $c->get_uid();
$uid = $uid_get['uid'];
$user_message = $c->show_user_by_id( $uid);//根据ID获取用户等基本信息
//获取用户的双向关注uid列表
$info=$c->bilateral_ids($uid);
print_r($info);
?>
打开得到如下数据:
Array ( [ids] => Array ( [0] => 2365402665 [1] => 2874824370 [2] => 2458103930 [3] => 2631415422 [4] => 1726492234 [5] => 3307625345 [6] => 1748961617 [7] => 1898400044 [8] => 5074409657 [9] => 1459729954 [10] => 1960937255 [11] => 3002010437 [12] => 1840024911 [13] => 1933041827 [14] => 3544004403 [15] => 2218615153 [16] => 1710952872 [17] => 3296525792 [18] => 2023869922 [19] => 1136908732 [20] => 5142045518 [21] => 2113440863 [22] => 2882182570 [23] => 2750918083 [24] => 5047720995 [25] => 3237485452 [26] => 2301448374 [27] => 2241922934 [28] => 3194061564 [29] => 1516453591 [30] => 3046227467 [31] => 2990824405 [32] => 2901804343 [33] => 2062251914 [34] => 1846033411 [35] => 3024328843 [36] => 3989444339 [37] => 3937835581 [38] => 2951303393 [39] => 38376110 [40] => 2403647687 [41] => 2637451094 [42] => 2257435150 [43] => 2997619907 [44] => 2272664314 [45] => 1858542007 [46] => 3566646574 [47] => 3017416653 [48] => 2017817897 [49] => 3270778184 ) [total_number] => 198 )
然后我们就可以根据UID去获取更多的信息,比如用户名,基础资料等。
内容有点多,我就不一一去演示了
有兴趣的朋友可以多看看saetv2.ex.class.php文件
官网提供的API:http://open.weibo.com/wiki/%E5%BE%AE%E5%8D%9AAPI
好啦,就此结束吧,毕竟只是作为入门介绍
有时间再写篇关于微博开放平台站内应用的入门介绍~See you
相关文章推荐
- OAuth2.0学习(1-9)新浪开放平台微博认证-web应用授权(授权码方式)
- OAuth2.0学习(1-2)OAuth2.0的一个企业级应用场景 - 新浪开放平台微博OAuth2.0认证
- 新浪微博开放平台站内应用开发流程直播(一)
- ios应用接入微信开放平台
- 新浪微博开放平台站内应用开发流程直播(二)
- OAuth2.0学习(1-11)新浪开放平台微博认证-使用OAuth2.0调用微博的开放API
- 微信开放平台开发(2) 网站应用微信登录
- 关于开放平台的OAuth2.0认证
- ios应用接入微信开放平台
- 基于新浪开放平台的企业微博影响力分析应用的学习笔记。
- 网站开放平台发布-开创应用个人创业
- Android应用接入微信开放平台
- 微信开放平台网站应用配置
- iOS备忘录之QQ、腾讯和微博开放平台创建应用需要的素材
- 微信开放平台开发(2) 网站应用微信登录
- 微信开放平台---网站应用开发---微信登录功能 简介
- 新浪微博开放平台站内应用开发流程直播(二)
- 新浪微博开放平台站内应用开发流程直播(一)
- 微店开放平台接入的应用类型
- 新浪微博开放平台接入