Android Twitter xauth Пример с использованием Twitter4j
Вопрос
Android: я пробую следующий пример Xauth для Android Share.
Аутентификация Xauth для Twitter Поделиться в Android?
System.setProperty("twitter4j.oauth.consumerKey", "your token");
System.setProperty("twitter4j.oauth.consumerSecret", "your token secret");
Twitter twitter = new TwitterFactory().getInstance(login, password);
AccessToken accessToken = twitter.getOAuthAccessToken();
//Then you must save your Token and Token secret from AccesToken
if (mAccessToken != null) {
if (mAccessToken.getToken() != null && mAccessToken.getTokenSecret() != null) {
saveAccessToken(mAccessToken.getToken(), mAccessToken.getTokenSecret());
}
}
У меня есть нелегальная статей
Exception Msg: java.lang.IllegalStateException: OAuth consumer key/secret combination not supplied
на следующей строке
AccessToken accessToken = twitter.getOAuthAccessToken();
Я внес изменения в подобные следование
Twitter twitter = new TwitterFactory().getInstance("login", "pass");
twitter.setOAuthConsumer(getString(R.string.twtAPIKey), getString(R.string.twtSecret));
AccessToken mAccessToken = twitter.getOAuthAccessToken();
И я снова получил исключениеException Msg: java.lang.IllegalStateException: Basic authenticated instance.
Любой рабочий пример Xauth?
Решение
Я использовал следующие
ConfigurationBuilder configurationBuilder = new ConfigurationBuilder();
configurationBuilder.setOAuthConsumerKey(Consumer__Key);
configurationBuilder.setOAuthConsumerSecret(Consumer_Secret);
Configuration configuration = configurationBuilder.build();
Twitter twitter = new TwitterFactory(configuration).getInstance("username","password");
AccessToken token = twitter.getOAuthAccessToken();
System.out.println("Access Token " +token );
String name = token.getScreenName();
System.out.println("Screen Name" +name);
PrintWriter out= response.getWriter();
System.out.println(token);
И успешно войти в Twitter, используя приложение Android, используя Xauth
Другие советы
Версия 2.2.2 Twitter4J как небольшое изменение. Это работает:
Configuration configuration = new ConfigurationBuilder()
.setOAuthConsumerKey("your_customer_key")
.setOAuthConsumerSecret("your_customer_secret")
.build();
Twitter twitter = new TwitterFactory(configuration).getInstance(new BasicAuthorization(username, password)); // yes, use "BasicAuthorization" although that seems strange
AccessToken token = twitter.getOAuthAccessToken();
Log.d(TAG, "Access token: " + token.getToken());
Log.d(TAG, "Access token secret: " + token.getTokenSecret());
Помните, что ваше приложение для клиента в Твиттере должно быть уполномочен использовать Xauth Прежде чем это сработает.