Statuses/user timeline

跳转到: 导航, 搜索
(Parameters:)
 
(未显示9个用户的58个中间版本)
第1行: 第1行:
== statuses/user_timeline ==
+
{{api_desc2|
返回登陆用户的发布的最近20条围脖信息。这个是网络上时间轴上或第三方个信息页是等同的。
+
uri=statuses/user_timeline|
 
+
desc=返回用户最新发表的微博消息列表。|
Returns the 20 most recent statuses posted from the authenticating user. It's also possible to request another user's timeline via the id parameter. This is the equivalent of the Web /<user> page for your own user, or the profile page for a third party.
+
format=XML/JSON|
 
+
httpMethod=GET|
=== URL: ===
+
needAuth=true|
http://api.t.sina.com.cn/statuses/user_timeline.format
+
rateLimit=true|
 +
params={{api_args|:id|false|int64/string|根据用户ID(int64)或者微博昵称(string)返回指定用户的最新微博消息列表。该参数为REST风格参数,参见注意事项}}
 +
{{api_args|user_id|false|int64|用户ID,主要是用来区分用户ID跟微博昵称。当微博昵称为数字导致和用户ID产生歧义,特别是当微博昵称和用户ID一样的时候,建议使用该参数}}
 +
{{api_args|screen_name|false|string|微博昵称,主要是用来区分用户UID跟微博昵称,当二者一样而产生歧义的时候,建议使用该参数}}
 +
{{api_args|since_id|false|int64|若指定此参数,则只返回ID比since_id大(即比since_id发表时间晚的)的微博消息。}}
 +
{{api_args|max_id|false|int64|若指定此参数,则返回ID小于或等于max_id的微博消息}}
 +
{{api_args|count|false|int,默认值20,最大值200。|指定每页返回的记录条数。}}
 +
{{api_args|page|false|int,默认值1。|页码。注意:最多返回200条分页内容。}}
 +
{{api_args_colspan|1=<font style="color:#ee3333">如果:id、user_id、screen_name三个参数均未指定,则返回当前登录用户最近发表的微博消息列表。</font>}}
 +
{{api_args|base_app|false|int|是否基于当前应用来获取数据。1为限制本应用微博,0为不做限制。}}
 +
{{api_args|feature|false|int|微博类型,0全部,1原创,2图片,3视频,4音乐. 返回指定类型的微博信息内容。}}|
 +
getParam=&user_id=11051|
 +
postParam=|
 +
result=
 +
===XML示例===
 +
<pre>
 +
<?xml version="1.0" encoding="UTF-8"?>
 +
<statuses>
 +
  <status>
 +
    <created_at>Mon Nov 29 16:08:43 +0800 2010</created_at>
 +
    <id>3958728723</id>
 +
    <text>各位开发者,我们的论坛上线啦~http://sinaurl.cn/h4FWc7 欢迎大家的参与~另外,关于技术相关的问题,可以在论坛上提出,也可以@微博API 这个官方技术支持账号哦~感谢大家对开放平台的支持~[呵呵]</text>
 +
    <source>
 +
      <a href="http://t.sina.com.cn">新浪微博</a>
 +
    </source>
 +
    <favorited>false</favorited>
 +
    <truncated>false</truncated>
 +
    <geo/>
 +
    <in_reply_to_status_id/>
 +
    <in_reply_to_user_id/>
 +
    <in_reply_to_screen_name/>
 +
    <user>
 +
      <id>11051</id>
 +
      <screen_name>微博开放平台</screen_name>
 +
      <name>微博开放平台</name>
 +
      <province>11</province>
 +
      <city>8</city>
 +
      <location>北京 海淀区</location>
 +
      <description>新浪微博开放平台市场推广官方账号,如有技术问题,请@微博API或者发私信给微博API</description>
 +
      <url>http://open.t.sina.com.cn/</url>
 +
      <profile_image_url>http://tp4.sinaimg.cn/11051/50/1280283165/1</profile_image_url>
 +
      <domain>openapi</domain>
 +
      <gender>m</gender>
 +
      <followers_count>13034</followers_count>
 +
      <friends_count>5</friends_count>
 +
      <statuses_count>157</statuses_count>
 +
      <favourites_count>0</favourites_count>
 +
      <created_at>Wed Jan 20 00:00:00 +0800 2010</created_at>
 +
      <following>false</following>
 +
      <verified>true</verified>
 +
      <allow_all_act_msg>true</allow_all_act_msg>
 +
      <geo_enabled>true</geo_enabled>
 +
    </user>
 +
  </status>
 +
...
 +
</statuses>
 +
</pre>
 +
===JSON示例===
 +
<pre>
 +
[
 +
    {
 +
        "created_at" : "Mon Nov 29 16:08:43 +0800 2010",
 +
        "text" : "各位开发者,我们的论坛上线啦~http://sinaurl.cn/h4FWc7 欢迎大家的参与~另外,关于技术相关的问题,可以在论坛上提出,也可以@微博API 这个官方技术支持账号哦~感谢大家对开放平台的支持~[呵呵]",
 +
        "truncated" : false,
 +
        "in_reply_to_status_id" : "",
 +
        "in_reply_to_screen_name" : "",
 +
        "geo" : null,
 +
        "user" :
 +
        {
 +
            "name" : "微博开放平台",
 +
            "domain" : "openapi",
 +
            "geo_enabled" : true,
 +
            "followers_count" : 13034,
 +
            "statuses_count" : 157,
 +
            "favourites_count" : 0,
 +
            "city" : "8",
 +
            "description" : "新浪微博开放平台市场推广官方账号,如有技术问题,请@微博API或者发私信给微博API",
 +
            "verified" : true,
 +
            "id" : 11051,
 +
            "gender" : "m",
 +
            "friends_count" : 5,
 +
            "screen_name" : "微博开放平台",
 +
            "allow_all_act_msg" : true,
 +
            "following" : false,
 +
            "url" : "http://open.t.sina.com.cn/",
 +
            "profile_image_url" : "http://tp4.sinaimg.cn/11051/50/1280283165/1",
 +
            "created_at" : "Wed Jan 20 00:00:00 +0800 2010",
 +
            "province" : "11",
 +
            "location" : "北京 海淀区"
 +
        },
 +
        "favorited" : false,
 +
        "in_reply_to_user_id" : "",
 +
        "id" : 3958728723,
 +
        "source" : "<a href=\"http://t.sina.com.cn\" rel=\"nofollow\">新浪微博</a>"
 +
    },
 +
...
 +
]
 +
</pre>
 +
{{Param_status}}
 +
{{Param_user}}|
 +
useAge=
 +
* :id为REST风格的参数,使用该参数的URL为:<br/> http://api.t.sina.com.cn/statuses/user_timeline/:id.format <br/> 使用示例如下:<br/> http://api.t.sina.com.cn/statuses/user_timeline/11051.xml?source=appkey<br/>http://api.t.sina.com.cn/statuses/user_timeline/timyang.json?source=appkey
 +
* 默认返回最近15天以内的微博信息
 +
* 由于分页限制,暂时最多只能返回用户最新的200条微博信息
 +
* 用户最多只能请求到最近200条记录|
 +
otherInfo=
 +
===Java示例===
 +
请从 [[SDK | 微博SDK开发包下载]] 下载Java SDK<br>
 +
代码示例如下:
 +
<pre>
 +
package weibo4j.examples;
 
   
 
   
=== Formats: ===
+
  import java.util.List;
xml, json, rss, atom
+
import weibo4j.Status;
 +
import weibo4j.Weibo;
 +
import weibo4j.WeiboException;
 
   
 
   
=== HTTP Method(s): ===
+
public class GetUserTimeline {
GET
+
 
   
 
   
=== Requires Authentication (about authentication): ===
+
/**
true, if requesting a protected user's timeline
+
* 获取用户发布的微博信息列表
+
* @param args
=== API rate limited (about rate limiting): ===
+
*/
1 call per request
+
public static void main(String[] args) {
 
+
System.setProperty("weibo4j.oauth.consumerKey", Weibo.CONSUMER_KEY);
=== Parameters: ===
+
    System.setProperty("weibo4j.oauth.consumerSecret", Weibo.CONSUMER_SECRET);
* id:  可选参数. 根据指定用户ID或用户帐号来返回围脖信息。
+
try {
o Example: http://api.t.sina.com.cn/statuses/user_timeline/12345.xml or http://twitter.com/statuses/user_timeline/bob.json.  
+
//获取24小时内前20条用户的微博信息;args[2]:用户ID
* user_id:  可选参数.  指定用户ID来返回围脖信息,主要是用来区分用户ID跟用户账号一样,产生歧义的时候,特别是在用户账号为数字导致和用户id发生歧义。
+
List<Status> statuses = getWeibo(false,args).getUserTimeline(args[2]);
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?user_id=1401881
+
for (Status status : statuses) {
* screen_name. 可选参数. 指定用户账号来返回围脖信息,主要是用来区分用户ID跟用户账号一样,产生歧义的时候。
+
            System.out.println(status.getUser().getName() + ":" +
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?screen_name=101010
+
                              status.getText());
* since_id:  可选参数.   返回ID比数值since_id大(比since_id时间晚的)的围脖信息。 
+
        }
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?since_id=12345
+
} catch (WeiboException e) {
* max_id:  返回ID不大于max_id(时间不晚于max_id)的围脖信息。
+
e.printStackTrace();
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?max_id=54321
+
}
* count:  可选参数. 每次返回的最大记录数(即页面大小),不大于200。 
+
}
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?count=200
+
* page: 可选参数. 返回结果的页序号。注意:有分页限制。
+
  private static Weibo getWeibo(boolean isOauth,String[] args) {
o Example: http://api.t.sina.com.cn/statuses/user_timeline.rss?page=3
+
Weibo weibo = new Weibo();
 
+
if(isOauth) {//oauth验证方式 args[0]:访问的token;args[1]:访问的密匙
 
+
weibo.setToken(args[0], args[1]);
* id.  Optional.  Specifies the ID or screen name of the user for whom to return the user_timeline. 
+
}else {//用户登录方式
o Example: http://api.t.sina.com.cn/statuses/user_timeline/12345.xml or http://twitter.com/statuses/user_timeline/bob.json.
+
    weibo.setUserId(args[0]);//用户名/ID
* user_id.  Optional.  Specfies the ID of the user for whom to return the user_timeline. Helpful for disambiguating when a valid user ID is also a valid screen name.
+
    weibo.setPassword(args[1]);//密码
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?user_id=1401881
+
}
* screen_name.  Optional.  Specfies the screen name of the user for whom to return the user_timeline. Helpful for disambiguating when a valid screen name is also a user ID.
+
return weibo;
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?screen_name=101010
+
}
* since_id. Optional.  Returns only statuses with an ID greater than (that is, more recent than) the specified ID. 
+
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?since_id=12345
+
* max_id. Returns only statuses with an ID less than (that is, older than) or equal to the specified ID.
+
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?max_id=54321
+
* count. Optional.  Specifies the number of statuses to retrieve. May not be greater than 200. 
+
o Example: http://api.t.sina.com.cn/statuses/user_timeline.xml?count=200
+
* page. Optional. Specifies the page of results to retrieve. Note: there are pagination limits.
+
o Example: http://api.t.sina.com.cn/statuses/user_timeline.rss?page=3
+
 
+
=== Usage notes: ===
+
*You will only be able to access the latest 3200 statuses from a user's timeline due to pagination limits.
+
 
   
 
   
=== Response ===
+
}
(about return values): XML example (truncated):
+
</pre>
<?xml version="1.0" encoding="UTF-8"?>
+
===PHP示例===
<statuses>
+
请从 [[SDK | 微博SDK开发包下载]] 处下载PHP SDK(支持OAuth验证之版本)<br>  
<status>
+
代码示例如下:
  <created_at>Tue Apr 07 22:52:51 +0000 2009</created_at>
+
<pre>
  <id>1472669360</id>
+
//Statuses/user timeline
  <text>At least I can get your humor through tweets. RT @abdur: I don't mean this in a bad way, but genetically speaking your a cul-de-sac.</text>
+
//获取24小时内前20条用户的微博信息
  <source>&lt;a href="http://www.tweetdeck.com/">TweetDeck&lt;/a></source>
+
$c = new WeiboClient( WB_AKEY ,
  <truncated>false</truncated>
+
                      WB_SKEY ,  
  <in_reply_to_status_id></in_reply_to_status_id>
+
                      $_SESSION['last_key']['oauth_token'] ,  
  <in_reply_to_user_id></in_reply_to_user_id>
+
                      $_SESSION['last_key']['oauth_token_secret']  );
  <favorited>false</favorited>
+
  <in_reply_to_screen_name></in_reply_to_screen_name>
+
  <user>
+
  <id>1401881</id>
+
  <name>Doug Williams</name>
+
  <screen_name>dougw</screen_name>
+
  <location>San Francisco, CA</location>
+
  <description>Twitter API Support. Internet, greed, users, dougw and opportunities are my passions.</description>
+
  <profile_image_url>http://t.sina.com.cn/t_production/profile_images/59648642/avatar_normal.png</profile_image_url>
+
  <url>http://www.igudo.com</url>
+
  <protected>false</protected>
+
  <followers_count>1027</followers_count>
+
  <profile_background_color>9ae4e8</profile_background_color>
+
  <profile_text_color>000000</profile_text_color>
+
  <profile_link_color>0000ff</profile_link_color>
+
  <profile_sidebar_fill_color>e0ff92</profile_sidebar_fill_color>
+
  <profile_sidebar_border_color>87bc44</profile_sidebar_border_color>
+
  <friends_count>293</friends_count>
+
  <created_at>Sun Mar 18 06:42:26 +0000 2007</created_at>
+
  <favourites_count>0</favourites_count>
+
  <utc_offset>-18000</utc_offset>
+
  <time_zone>Eastern Time (US & Canada)</time_zone>
+
  <profile_background_image_url>http://t.sina.com.cn/t_production/profile_background_images/2752608/t_bg_grass.jpg</profile_background_image_url>
+
  <profile_background_tile>false</profile_background_tile>
+
  <statuses_count>3390</statuses_count>
+
  <notifications>false</notifications>
+
  <following>false</following>
+
  <verified>true</verified>
+
  </user>
+
  <geo/>
+
</status>
+
    ... truncated ...
+
</statuses>
+
  
=== Usage examples: ===
+
//$u_id:用户ID
cURL (about cURL):
+
$u_id = "用户ID";
curl http://api.t.sina.com.cn/statuses/user_timeline.xml?screen_name=dougw
+
$msg  = $c->user_timeline($u_id);
 +
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.";";
 +
}
 +
</pre>
 +
}}

2010年12月17日 (五) 18:11的最后版本

目录

statuses/user_timeline

返回用户最新发表的微博消息列表。

URL

http://api.t.sina.com.cn/statuses/user_timeline.(json%7Cxml)

支持格式

XML/JSON

HTTP请求方式

GET

是否需要登录

true
关于授权机制,参见授权机制声明

请求数限制

true
关于请求数限制,参见接口访问权限说明

请求参数

  必选 类型及范围 说明
source true string 申请应用时分配的AppKey,调用接口时候代表应用的唯一身份。(采用OAuth授权方式不需要此参数)
:id false int64/string 根据用户ID(int64)或者微博昵称(string)返回指定用户的最新微博消息列表。该参数为REST风格参数,参见注意事项
user_id false int64 用户ID,主要是用来区分用户ID跟微博昵称。当微博昵称为数字导致和用户ID产生歧义,特别是当微博昵称和用户ID一样的时候,建议使用该参数
screen_name false string 微博昵称,主要是用来区分用户UID跟微博昵称,当二者一样而产生歧义的时候,建议使用该参数
since_id false int64 若指定此参数,则只返回ID比since_id大(即比since_id发表时间晚的)的微博消息。
max_id false int64 若指定此参数,则返回ID小于或等于max_id的微博消息
count false int,默认值20,最大值200。 指定每页返回的记录条数。
page false int,默认值1。 页码。注意:最多返回200条分页内容。
如果:id、user_id、screen_name三个参数均未指定,则返回当前登录用户最近发表的微博消息列表。
base_app false int 是否基于当前应用来获取数据。1为限制本应用微博,0为不做限制。
feature false int 微博类型,0全部,1原创,2图片,3视频,4音乐. 返回指定类型的微博信息内容。

注意事项

返回结果

XML示例

<?xml version="1.0" encoding="UTF-8"?>
<statuses>
  <status>
    <created_at>Mon Nov 29 16:08:43 +0800 2010</created_at>
    <id>3958728723</id>
    <text>各位开发者,我们的论坛上线啦~http://sinaurl.cn/h4FWc7 欢迎大家的参与~另外,关于技术相关的问题,可以在论坛上提出,也可以@微博API 这个官方技术支持账号哦~感谢大家对开放平台的支持~[呵呵]</text>
    <source>
      <a href="http://t.sina.com.cn">新浪微博</a>
    </source>
    <favorited>false</favorited>
    <truncated>false</truncated>
    <geo/>
    <in_reply_to_status_id/>
    <in_reply_to_user_id/>
    <in_reply_to_screen_name/>
    <user>
      <id>11051</id>
      <screen_name>微博开放平台</screen_name>
      <name>微博开放平台</name>
      <province>11</province>
      <city>8</city>
      <location>北京 海淀区</location>
      <description>新浪微博开放平台市场推广官方账号,如有技术问题,请@微博API或者发私信给微博API</description>
      <url>http://open.t.sina.com.cn/</url>
      <profile_image_url>http://tp4.sinaimg.cn/11051/50/1280283165/1</profile_image_url>
      <domain>openapi</domain>
      <gender>m</gender>
      <followers_count>13034</followers_count>
      <friends_count>5</friends_count>
      <statuses_count>157</statuses_count>
      <favourites_count>0</favourites_count>
      <created_at>Wed Jan 20 00:00:00 +0800 2010</created_at>
      <following>false</following>
      <verified>true</verified>
      <allow_all_act_msg>true</allow_all_act_msg>
      <geo_enabled>true</geo_enabled>
    </user>
  </status>
...
</statuses>

JSON示例

[
    {
        "created_at" : "Mon Nov 29 16:08:43 +0800 2010",
        "text" : "各位开发者,我们的论坛上线啦~http://sinaurl.cn/h4FWc7 欢迎大家的参与~另外,关于技术相关的问题,可以在论坛上提出,也可以@微博API 这个官方技术支持账号哦~感谢大家对开放平台的支持~[呵呵]",
        "truncated" : false,
        "in_reply_to_status_id" : "",
        "in_reply_to_screen_name" : "",
        "geo" : null,
        "user" : 
        {
            "name" : "微博开放平台",
            "domain" : "openapi",
            "geo_enabled" : true,
            "followers_count" : 13034,
            "statuses_count" : 157,
            "favourites_count" : 0,
            "city" : "8",
            "description" : "新浪微博开放平台市场推广官方账号,如有技术问题,请@微博API或者发私信给微博API",
            "verified" : true,
            "id" : 11051,
            "gender" : "m",
            "friends_count" : 5,
            "screen_name" : "微博开放平台",
            "allow_all_act_msg" : true,
            "following" : false,
            "url" : "http://open.t.sina.com.cn/",
            "profile_image_url" : "http://tp4.sinaimg.cn/11051/50/1280283165/1",
            "created_at" : "Wed Jan 20 00:00:00 +0800 2010",
            "province" : "11",
            "location" : "北京 海淀区"
        },
        "favorited" : false,
        "in_reply_to_user_id" : "",
        "id" : 3958728723,
        "source" : "<a href=\"http://t.sina.com.cn\" rel=\"nofollow\">新浪微博</a>"
    },
...
]

字段说明 - status

  • created_at: 创建时间
  • id: 微博ID
  • text: 微博信息内容
  • source: 微博来源
  • favorited: 是否已收藏
  • truncated: 是否被截断
  • in_reply_to_status_id: 回复ID
  • in_reply_to_user_id: 回复人UID
  • in_reply_to_screen_name: 回复人昵称
  • thumbnail_pic: 缩略图
  • bmiddle_pic: 中型图片
  • original_pic:原始图片
  • user: 作者信息
  • retweeted_status: 转发的博文,内容为status,如果不是转发,则没有此字段

字段说明 - user

  • id: 用户UID
  • screen_name: 微博昵称
  • name: 友好显示名称,同微博昵称
  • province: 省份编码(参考省份编码表)
  • city: 城市编码(参考城市编码表)
  • location:地址
  • description: 个人描述
  • url: 用户博客地址
  • profile_image_url: 自定义图像
  • domain: 用户个性化URL
  • gender: 性别,m--男,f--女,n--未知
  • followers_count: 粉丝数
  • friends_count: 关注数
  • statuses_count: 微博数
  • favourites_count: 收藏数
  • created_at: 创建时间
  • following: 是否已关注(此特性暂不支持)
  • verified: 加V标示,是否微博认证用户

其他

Java示例

请从 微博SDK开发包下载 下载Java SDK
代码示例如下:

 package weibo4j.examples;
 
 import java.util.List;
 import weibo4j.Status;
 import weibo4j.Weibo;
 import weibo4j.WeiboException;
 
 public class GetUserTimeline {
 
 	/**
 	 * 获取用户发布的微博信息列表 
 	 * @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 {
 			//获取24小时内前20条用户的微博信息;args[2]:用户ID
 			List<Status> statuses = getWeibo(false,args).getUserTimeline(args[2]);
 			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/user timeline
//获取24小时内前20条用户的微博信息
$c = new WeiboClient( WB_AKEY , 
                      WB_SKEY , 
                      $_SESSION['last_key']['oauth_token'] , 
                      $_SESSION['last_key']['oauth_token_secret']  );

//$u_id:用户ID
$u_id = "用户ID";
$msg  = $c->user_timeline($u_id);
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.";";
}
文档更新时间: 2010-12-17