Statuses/friends timeline
(→Java示例) |
(→PHP示例) |
||
第160行: | 第160行: | ||
} | } | ||
====PHP示例==== | ====PHP示例==== | ||
+ | 请从 [[SDK | 微博SDK开发包下载]] 处下载PHP SDK(支持OAuth验证之版本)<br> | ||
+ | 代码示例如下: | ||
<pre> | <pre> | ||
//Statuses/friends timeline | //Statuses/friends timeline | ||
//获取前20条最新更新的公共微博消息 | //获取前20条最新更新的公共微博消息 | ||
− | $c = new WeiboClient( WB_AKEY , WB_SKEY , $_SESSION['last_key']['oauth_token'] , $_SESSION['last_key']['oauth_token_secret'] ); | + | $c = new WeiboClient( WB_AKEY , |
+ | WB_SKEY , | ||
+ | $_SESSION['last_key']['oauth_token'] , | ||
+ | $_SESSION['last_key']['oauth_token_secret'] ); | ||
+ | |||
$msg = $c->friends_timeline(); | $msg = $c->friends_timeline(); | ||
if ($msg === false || $msg === null){ | if ($msg === false || $msg === null){ |
2010年8月4日 (三) 14:52的版本
目录 |
statuses/friends_timeline
返回用户所有关注用户最新n条微博信息。和用户“我的首页”返回内容相同。
URL
http://api.t.sina.com.cn/statuses/friends_timeline.format or http://api.t.sina.com.cn/statuses/home_timeline.format
格式
xml, json
HTTP请求方式
GET
是否需要登录
true
请求参数
- since_id: 可选参数(微博信息ID). 只返回ID比since_id大(比since_id时间晚的)的微博信息内容。
- max_id: 可选参数(微博信息ID). 返回ID不大于max_id的微博信息内容。
- count: 可选参数. 每次返回的最大记录数,不能超过200,默认20.
- page: 可选参数. 返回结果的页序号。注意:有分页限制。根据用户关注对象发表的数量,通常最多返回1,000条最新微博分页内容, 默认1
返回结果
XML示例:
<?xml version="1.0" encoding="UTF-8"?> <statuses> <status> <created_at>Fri Dec 25 13:07:17 +0800 2009</created_at> <id>14265</id> <text>在群星之中,有一颗星是指导着我的生命通过不可知的黑暗的。 </text> <source> <a id="0" href="http://t.sina.com.cn">Web</a> </source> <favorited>false</favorited> <truncated>false</truncated> <geo/> <in_reply_to_status_id></in_reply_to_status_id> <in_reply_to_user_id></in_reply_to_user_id> <in_reply_to_screen_name></in_reply_to_screen_name> <thumbnail_pic>http://static16.photo.sina.com.cn/thumbnail/62988d06tcbbc377f7bbf</thumbnail_pic> <bmiddle_pic>http://static16.photo.sina.com.cn/bmiddle/62988d06tcbbc377f7bbf</bmiddle_pic> <original_pic>http://static16.photo.sina.com.cn/orignal/62988d06tcbbc377f7bbf</original_pic> <user> <id>6719</id> <screen_name>name_6719</screen_name> <name>name_6719</name> <province></province> <city></city> <location></location> <description></description> <url>http://timyang.net</url> <profile_image_url>http://tp4.sinaimg.cn/6719/50/0</profile_image_url> <domain>6719</domain> <gender></gender> <followers_count>18</followers_count> <friends_count>30</friends_count> <statuses_count>0</statuses_count> <favourites_count>0</favourites_count> <created_at>Thu Jan 01 08:00:00 +0800 1970</created_at> <following>false</following> <verified>false</verified> <geo_enabled>false</geo_enabled> </user> </status> ... </statuses>
JSON:示例
[ {"created_at":"Wed Jan 06 15:46:42 +0800 2010", "id":142272, "text":"ttfffff asf", "source":"<a id=\"0\" href=\"http://t.sina.com.cn/\" rel=\"nofollow\">Web</a>", "favorited":false, "truncated":false, "in_reply_to_status_id":"", "in_reply_to_user_id":"", "in_reply_to_screen_name":"", "geo":null, "user":{
"id":11075, "screen_name":"name_11075", "name":"name_11075", "province":null, "city":null, "location":"", "description":"", "url":"", "profile_image_url":"http://tp4.sinaimg.cn/11075/50/0", "domain":"11075", "followers_count":28, "friends_count":50, "statuses_count":0, "favourites_count":26, "created_at":"Thu Jan 01 08:00:00 +0800 1970", "following":false, "geo_enabled":false, "verified":true} } ,{} ,... ]
使用示例
需修改appkey
- xml:
curl -u uid:password http://api.t.sina.com.cn/statuses/friends_timeline.xml?source=appkey
- json:
curl -u uid:password http://api.t.sina.com.cn/statuses/friends_timeline.json?source=appkey
Java示例
请从 微博SDK开发包下载 下载Java SDK
代码示意如下:
package weibo4j.examples; import java.util.List; import weibo4j.Status; import weibo4j.Weibo; import weibo4j.WeiboException; public class GetFriendsTimeline { /** * 获取当前用户所关注用户的最新微博信息 (别名: statuses/home_timeline) * @param args */ public static void main(String[] args) { System.setProperty("weibo4j.oauth.consumerKey", Weibo.CONSUMER_KEY); System.setProperty("weibo4j.oauth.consumerSecret", Weibo.CONSUMER_SECRET); try { //获取前20条关注用户的微博信息 List<Status> statuses = getWeibo(true,args).getFriendsTimeline(); for (Status status : statuses) { System.out.println(status.getUser().getName() + ":" + status.getText()); } } catch (WeiboException e) { e.printStackTrace(); } } private static Weibo getWeibo(boolean isOauth,String[] args) { Weibo weibo = new Weibo(); if(isOauth) {//oauth验证方式 args[0]:访问的token;args[1]:访问的密匙 weibo.setToken(args[0], args[1]); }else {//用户登录方式 weibo.setUserId(args[0]);//用户名/ID weibo.setPassword(args[1]);//密码 } return weibo; } }
PHP示例
请从 微博SDK开发包下载 处下载PHP SDK(支持OAuth验证之版本)
代码示例如下:
//Statuses/friends timeline //获取前20条最新更新的公共微博消息 $c = new WeiboClient( WB_AKEY , WB_SKEY , $_SESSION['last_key']['oauth_token'] , $_SESSION['last_key']['oauth_token_secret'] ); $msg = $c->friends_timeline(); if ($msg === false || $msg === null){ echo "Error occured"; return false; } if (isset($msg['error_code']) && isset($msg['error'])){ echo ('Error_code: '.$msg['error_code'].'; Error: '.$msg['error'] ); return false; } foreach ($msg as $data){ $user_name = $data['user']['name']; $text = $data['text']; echo $user_name."=".$text.";"; }