使用Twitter Fabric获取user_timeline时禁止获取403



我一直在尝试实现Fabric,以从用户那里获得5条最新推文的列表。它很好地工作了几个小时,然后就停止了工作。我想在不让用户登录的情况下这样做,而且据我所知,API允许留言登录来阅读推文,但这可能对速率限制有更大的影响?

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    TwitterAuthConfig authConfig = new TwitterAuthConfig(TWITTER_KEY, TWITTER_SECRET);
    Fabric.with(this, new Twitter(authConfig), new Crashlytics());
    TwitterCore.getInstance().logInGuest(new Callback() {
        @Override
        public void success(Result result) {
            AppSession session = (AppSession) result.data;
            getTweets();
        }
        @Override
        public void failure(TwitterException exception) {
            // unable to get an AppSession with guest auth
        }
    });
}
    public void getTweets() {
    TwitterApiClient twitterApiClient = TwitterCore.getInstance().getApiClient();
    StatusesService statusesService = twitterApiClient.getStatusesService();

    statusesService.userTimeline([USERID], null, 5, null, null, null, true, null, false, new Callback<List<Tweet>>() {
        @Override
        public void success(Result <List<Tweet>> result) {
            for(Tweet Tweet : result.data) {
                tweetList.add(Tweet.text);
            }
            createListView();
        }
        public void failure(TwitterException exception) {
            Log.e("Failure", exception.toString());
            exception.printStackTrace();
        }
    });
}

当我没有得到403时,一切都很完美,我的列表就会被填充。

现在,完全有可能是我的代码出了问题,导致我的费率限制被列入黑名单?否则我需要让用户登录才能向他们显示5条推文吗?或者我应该实现某种服务器端缓存吗?

感谢您的任何提示/帮助。

我想我可能已经弄明白了。看起来您必须从logInGuest回调中的success方法保存会话,然后将其传递给getApiClient。以下是一些迄今为止对我有效的代码:

private TweetViewFetchAdapter adapter;
...
adapter = new TweetViewFetchAdapter<CompactTweetView>(getActivity());
...
TwitterCore.getInstance().logInGuest( new Callback<AppSession>() {
    @Override
    public void success(Result<AppSession> appSessionResult) {
        AppSession session = appSessionResult.data;
        TwitterApiClient twitterApiClient =  TwitterCore.getInstance().getApiClient(session);
        twitterApiClient.getStatusesService().userTimeline(null, "RadioOkinawa864", 10, null, null, false, false, false, true, new Callback<List<Tweet>>() {
            @Override
            public void success(Result<List<Tweet>> listResult) {
                adapter.setTweets(listResult.data);
            }
            @Override
            public void failure(TwitterException e) {
                Toast.makeText(getActivity().getApplicationContext(), "Could not retrieve tweets", Toast.LENGTH_SHORT).show();
                e.printStackTrace();
            }
        });
    }
    @Override
    public void failure(TwitterException e) {
        Toast.makeText(getActivity().getApplicationContext(), "Could not get guest Twitter session", Toast.LENGTH_SHORT).show();
        e.printStackTrace();
    }
});

使用logInGuest时,请注意来宾AppSessions将在一段时间后过期。您的应用程序必须处理过期TwitterExceptions并请求另一个来宾AppSession。例如,

TwitterApiClient twitterApiClient =  TwitterCore.getInstance().getApiClient(guestAppSession);
twitterApiClient.getSearchService().tweets("#fabric", null, null, null, null, 50, null, null, null, true, new Callback<Search>() {
    @Override
    public void success(Result<Search> result) {
        // use result tweets
    }
    @Override
    public void failure(TwitterException exception) {
        final TwitterApiException apiException = (TwitterApiException) exception;
        final int errorCode = apiException.getErrorCode();
        if (errorCode == TwitterApiConstants.Errors.APP_AUTH_ERROR_CODE || errorCode == TwitterApiConstants.Errors.GUEST_AUTH_ERROR_CODE) {
            // request new guest AppSession (i.e. logInGuest)
            // optionally retry
        }
    }
});

请注意,AppSessions只能用于发出不需要用户上下文的API请求。例如,不能使用AppSession发送推文。您可以获取用户的公共推文时间线。请参阅TwitterKit Android REST API文档。

最后,如果您正在使用Twitter工具包组的TweetUi工具包中的TweetUtils.loadTweetTweetUtils.loadTweets助手,则会自动执行来宾身份验证和过期处理,您不需要自己调用logInGuest。

在我的情况下,api返回403禁止,并显示以下消息Your app may not allow guest auth. Please talk to us regarding upgrading your consumer key.

请确保您的状态不相同。

最新更新