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 все еще был не прав, - поэтому я принудительно закрыл приложение и после этого исключения не было.
Ответ 5
Я тоже наткнулся на эту проблему. Проверьте мое решение в другом потоке Android: Twitter4J Исключение (проблема с аутентификацией при получении завершена)
Ответ 6
У меня была такая же проблема и исправлена ее с помощью асинхронной задачи
как я ответил в следующей ссылке
Ошибка исключения Android Twitter:(