如何使用 Twitter 的 Java 库访问 Twitter API 资源 (twitter4j)

How to access Twitter API resources using Twitter's Java library (twitter4j)

我是 Twitter API 和 Twitter 的 twitter4j 库的新手。我最近注册了一个应用程序,以便能够使用 Twitter 的 API。 Twitter 已授予我消费者 API 密钥(API 密钥和 API 密钥),以及访问令牌和访问令牌机密。

问题是,我一直在尝试使用 twitter4j 对 Twitter 进行身份验证(使用上述密钥),但是在尝试访问任何 APIs 资源时,我收到一条错误消息说我由于速率限制,不允许访问。但是,当我从未能够查询 api 时,我怎么可能达到速率限制? :,(

这就是我正在尝试的(将敏感位替换为虚拟值):

@SpringBootApplication
public class App 
{

    private static final String CONSUMER_KEY = "FakeConsumerKey";
    private static final String CONSUMER_SECRET = "FakeConsumerSecret";

    public static void main( String[] args )
    {
        SpringApplication.run(App.class, args);
        System.out.println("Making an authentication request to"
                + " retrieve the bearer token...");



        OAuth2Token token;
        token = getOAuth2Token();

        ConfigurationBuilder cb = new ConfigurationBuilder();

        cb.setApplicationOnlyAuthEnabled(true);
        cb.setOAuthConsumerKey(CONSUMER_KEY);
        cb.setOAuthConsumerSecret(CONSUMER_SECRET);
        cb.setOAuth2TokenType(token.getTokenType());
        cb.setOAuth2AccessToken(token.getAccessToken());

        Twitter twitter = new TwitterFactory(cb.build()).getInstance();

        try {
            System.out.println("My screen name: " + twitter.getScreenName());
        } catch (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (TwitterException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }   

   }


    public static OAuth2Token getOAuth2Token()
    {
        OAuth2Token token = null;
        ConfigurationBuilder cb;

        cb = new ConfigurationBuilder();
        cb.setApplicationOnlyAuthEnabled(true);
        cb.setOAuthConsumerKey(CONSUMER_KEY);
        cb.setOAuthConsumerSecret(CONSUMER_SECRET);

        try
        {
            token = new TwitterFactory(cb.build())
                .getInstance().getOAuth2Token();

            System.out.println("token: " + token.getAccessToken());
        }
        catch (Exception e)
        {
            System.out.println("Can't get OAuth2 token");
            e.printStackTrace();
            System.exit(0);
        }

        return token;
    }

}

这是返回的错误:

403:The request is understood, but it has been refused. An accompanying error message will explain why. This code is used when requests are being denied due to update limits (https://support.twitter.com/articles/15364-about-twitter-limits-update-api-dm-and-following).
message - Your credentials do not allow access to this resource
code - 220

Relevant discussions can be found on the Internet at:
    http://www.google.co.jp/search?q=9a9caf7a or
    http://www.google.co.jp/search?q=bf94ba05
TwitterException{exceptionCode=[9a9caf7a-bf94ba05], statusCode=403, message=Your credentials do not allow access to this resource, code=220, retryAfter=-1, rateLimitStatus=null, version=4.0.6}
    at twitter4j.HttpClientImpl.handleRequest(HttpClientImpl.java:164)
    at twitter4j.HttpClientBase.request(HttpClientBase.java:57)
    at twitter4j.HttpClientBase.get(HttpClientBase.java:75)
    at twitter4j.TwitterBaseImpl.fillInIDAndScreenName(TwitterBaseImpl.java:133)
    at twitter4j.TwitterBaseImpl.fillInIDAndScreenName(TwitterBaseImpl.java:128)
    at twitter4j.TwitterBaseImpl.getScreenName(TwitterBaseImpl.java:108)
    at com.vismark.social.twitter.TwitterAccountService.App.main(App.java:41)

我哪里错了?

getScreenName 的定义

"Returns 验证用户的屏幕名称。 此方法可以在第一次调用时在内部调用 verifyCredentials() 如果 - 此实例由 Basic 进行身份验证,并提供电子邮件地址而不是屏幕名称,或者 - 此实例由 OAuth 进行身份验证。”

基于用户的身份验证必须使用 OAuth 1.0a 而不是 OAuth 2。您需要获取访问令牌,请遵循以下步骤:
https://developer.twitter.com/en/docs/basics/authentication/overview/using-oauth

获得访问令牌后,只需像这样更新 ConfigurationBuilder 即可:

    ConfigurationBuilder cb = new ConfigurationBuilder();

    cb.setApplicationOnlyAuthEnabled(false);
    cb.setOAuthConsumerKey(CONSUMER_KEY)
    .setOAuthConsumerSecret(CONSUMER_SECRET)
    .setOAuthAccessToken(ACCESS_TOKEN)
    .setOAuthAccessTokenSecret(ACCESS_TOKEN_SECRET);