Twitter4J + Android: вызов аутентификации - это исключение из памяти

Я использую библиотеку Twitter4J для проверки подлинности OAuth, но я получаю "Authentication Challenge Null Exception" еще до того, как она откроет страницу входа в Twitter.

Вот код.

    Twitter twitter = new TwitterFactory().getInstance();
    try
    {

        twitter.setOAuthConsumer(Startup.TWITTER_KEY, Startup.TWITTER_SECRET);

        String callbackURL = "twitter-client:///";

        RequestToken rToken = twitter.getOAuthRequestToken(callbackURL);

        startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(rToken.getAuthenticationURL())));

    }
    catch(IllegalStateException e)
    {
    // access token is already available, or consumer key/secret is not set.
        if(!twitter.getAuthorization().isEnabled()){
            System.out.println("OAuth consumer key/secret is not set.");
            System.exit(-1);
        }
    }
    catch(Exception e)
    {
        Toast.makeText(Home.this, "Network Host not responding: "+e.getMessage(),Toast.LENGTH_SHORT).show();  //This exception. 
    }

Исключение:

E/Home (4393): Получено проверка подлинности равна нулю E/Home (4393): Получено проверка подлинности Нулевые обсуждения могут быть Интернет по адресу: E/Home (4393):   http://www.google.co.jp/search?q=6c607809или E/Home (4393):   http://www.google.co.jp/search?q=0f1d8134E/Домой (4393): TwitterException {ExceptionCode = [6c607809-0f1d8134 cab4c0ac-d492a113], statusCode = -1, retryAfter = 0, rateLimitStatus = null, version = 2.2.2} E/Home (4393): at twitter4j.internal.http.HttpClientImpl.request(HttpClientImpl.java:204) E/Home (4393): at twitter4j.internal.http.HttpClientWrapper.request(HttpClientWrapper.java:65) E/Home (4393): at twitter4j.internal.http.HttpClientWrapper.post(HttpClientWrapper.java:102) E/Home (4393): at twitter4j.auth.OAuthAuthorization.getOAuthRequestToken(OAuthAuthorization.java:108) E/Home (4393): at twitter4j.TwitterBaseImpl.getOAuthRequestToken(TwitterBaseImpl.java:271) E/Home (4393): at com.sharj.trafik.view.Home.askOAuth(Home.java:157) E/Home (4393): at com.sharj.trafik.view.Home.access $0 (Home.java:143) E/Home (4393): at com.sharj.trafik.view.Home $3.onClick(Home.java:110) E/Home (4393): at android.view.View.performClick(View.java:2485) E/Home (4393): at android.view.View $PerformClick.run(View.java:9080) E/Home (4393): at android.os.Handler.handleCallback(Handler.java:587) E/Home (4393): at android.os.Handler.dispatchMessage(Handler.java:92) E/Home (4393): at android.os.Looper.loop(Looper.java:130) E/Home (4393): at android.app.ActivityThread.main(ActivityThread.java:3683) E/Home (4393): at java.lang.reflect.Method.invokeNative(Native Метод) E/Home (4393): at java.lang.reflect.Method.invoke(Method.java:507) E/Home (4393): at com.android.internal.os.ZygoteInit $MethodAndArgsCaller.run(ZygoteInit.java:839) E/Home (4393): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) E/Home (4393): at dalvik.system.NativeStart.main(Native Метод) E/Home (4393): причиненный: java.io.IOException: Получено проверка подлинности равна нулю E/Home (4393): at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.processAuthHeader(HttpURLConnectionImpl.java:1153) E/Home (4393): at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.processResponseHeaders(HttpURLConnectionImpl.java:1095) E/Home (4393): at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.retrieveResponse(HttpURLConnectionImpl.java:1048) E/Home (4393): at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:726) E/Home (4393): at org.apache.harmony.luni.internal.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:121) E/Home (4393): at twitter4j.internal.http.HttpResponseImpl. (HttpResponseImpl.java:35) E/Home (4393): at twitter4j.internal.http.HttpClientImpl.request(HttpClientImpl.java:168) E/Home (4393):... еще 18

Он содержит следующие ссылки, но у Google этого мало.

http://www.google.co.jp/search?q=6c607809

http://www.google.co.jp/search?q=0f1d8134

Ответы

Ответ 1

У меня была та же проблема. Оказалось, что если метка времени на вызове oAuth неверна, сервер возвращает ошибку состояния 401, которая на устройствах Android вызывает исключение "Ошибка проверки подлинности - это null". У всех устройств, у которых была эта проблема, были неправильные времена, и исправление времени устраняло проблему.

Возможно, это и ваша проблема?

Ответ 2

У меня также была та же проблема. Сначала я получал его при выполнении getOAuthRequestToken(). Мой потребительский ключ и секрет потребителя поступали из файла .properties, и у них было конечное пространство, поэтому они были признаны недействительными API-интерфейсом Twitter.

После этого я также получал то же самое 401 при выполнении getOAuthAccessToken(). Здесь я не был прав на сохранение и повторное построение объекта RequestToken.

Ответ 3

Это произошло для меня, когда я дважды вызывал следующее:

 requestToken = twitter.getOAuthRequestToken();
    return requestToken.getAuthorizationURL();

Ответ 4

FIXED: У меня было это исключение даже после того, как я установил дату и время, но когда я посмотрел в logcat на параметры, которые отправили на сервер, timestamp все еще был не прав, - поэтому я принудительно закрыл приложение и после этого исключения не было.

Ответ 6

У меня была такая же проблема и исправлена ​​ее с помощью асинхронной задачи как я ответил в следующей ссылке Ошибка исключения Android Twitter:(