获取API 1.1的最新推文

时间:2012-09-12 14:24:42

标签: twitter

我一直用这个地址来获取我的所有推文:

http://api.twitter.com/1/statuses/user_timeline.json?screen_name=enriquemoreno

但是由于API 1.1已经淘汰而API 1已弃用,我想我会尝试更改。但新地址不起作用:

http://api.twitter.com/1.1/statuses/user_timeline.json?screen_name=enriquemoreno

我错过了什么?

2 个答案:

答案 0 :(得分:17)

Someone在vanilla javascript中写了一个(聪明的)片段来获取twitter小部件:

/*********************************************************************
      #### Twitter Post Fetcher! ####
      Coded by Jason Mayes 2013.
      www.jasonmayes.com
      Please keep this disclaimer with my code if you use it. Thanks. :-)
      Got feedback or questions, ask here: http://goo.gl/JinwJ
    *********************************************************************/
    var twitterFetcher=function(){var d=null;return{fetch:function(a,b){d=b;var c=document.createElement("script");c.type="text/javascript";c.src="http://cdn.syndication.twimg.com/widgets/timelines/"+a+"?&lang=en&callback=twitterFetcher.callback&suppress_response_codes=true&rnd="+Math.random();document.getElementsByTagName("head")[0].appendChild(c)},callback:function(a){var b=document.createElement("div");b.innerHTML=a.body;a=b.getElementsByClassName("e-entry-title");d(a)}}}();

    /*
    * ### HOW TO USE: ###
    * Create an ID:
    * Go to www.twitter.com and sign in as normal, go to your settings page.
    * Go to "Widgets" on the left hand side.
    * Create a new widget for "user timeline". Feel free to check "exclude replies"
    * if you dont want replies in results.
    * Now go back to settings page, and then go back to widgets page, you should
    * see the widget you just created. Click edit.
    * Now look at the URL in your web browser, you will see a long number like this:
    * 345735908357048478
    * Use this as your ID below instead!
    */

    twitterFetcher.fetch('345170787868762112', function(tweets){
      // Do what you want with your tweets here! For example:
      var x = tweets.length;
      var n = 0;
      var element = document.getElementById('tweets');
      var html = '<ul>';
      while(n < x) {
        if (tweets[n].innerText) {
          html += '<li>' + tweets[n].innerText + '</li>';
        } else {
          html += '<li>' + tweets[n].textContent + '</li>';
        }
        n++;
      }
      html += '</ul>';
      element.innerHTML = html;
    });

http://jsfiddle.net/jmayes/maT2Z/

不是最干净的方式,也许不是面向未来的,但是现在唯一的解决方案(我知道)在没有OAuth和服务器端支持的情况下访问Twitter数据。

答案 1 :(得分:2)