AndroidアプリにOAuthを設定しています。それをテストするために、私は次のことを行いました:signpost-core-1.2.1.1.jarとsignpost-commonshttp4-1.2.1.1.jarをプロジェクトに追加し、変数「CommonsHttpOAuthConsumerconsumer」と「CommonsHttpOAuthProviderprovider」を追加しました。ボタンがクリックされた:
consumer = new CommonsHttpOAuthConsumer("xxx", "yyy");
provider = new CommonsHttpOAuthProvider("https://api.twitter.com/oauth/request_token",
"https://api.twitter.com/oauth/access_token",
"https://api.twitter.com/oauth/authorize");
oauthUrl = provider.retrieveRequestToken(consumer, "myapp://twitterOauth");
persistOAuthData();
this.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(oauthUrl)));
persistOAuthData()は次のことを行います。
protected void persistOAuthData()
{
try
{
FileOutputStream providerFOS = this.openFileOutput("provider.dat", MODE_PRIVATE);
ObjectOutputStream providerOOS = new ObjectOutputStream(providerFOS);
providerOOS.writeObject(this.provider);
providerOOS.close();
FileOutputStream consumerFOS = this.openFileOutput("consumer.dat", MODE_PRIVATE);
ObjectOutputStream consumerOOS = new ObjectOutputStream(consumerFOS);
consumerOOS.writeObject(this.consumer);
consumerOOS.close();
}
catch (Exception e) { }
}
したがって、ここで説明するように、コンシューマーとプロバイダーはブラウザーを開く前に保存されます。
onResume()メソッドで、プロバイダーとコンシューマーのデータをロードし、次のことを行います。
Uri uri = this.getIntent().getData();
if (uri != null && uri.getScheme().equals("myapp") && uri.getHost().equals("twitterOauth"))
{
verifier = uri.getQueryParameter(oauth.signpost.OAuth.OAUTH_VERIFIER);
if (!verifier.equals(""))
{
loadOauthData();
try
{
provider.retrieveAccessToken(consumer, verifier);
}
catch (OAuthMessageSignerException e) {
e.printStackTrace();
} catch (OAuthNotAuthorizedException e) {
e.printStackTrace();
} catch (OAuthExpectationFailedException e) {
e.printStackTrace();
} catch (OAuthCommunicationException e) {
e.printStackTrace();
}
}
}
したがって、機能するものは次のとおりです。1)requestTokenとrequestSecretを取得します。2)oauthUrlを取得します。3)アプリを認証するためにブラウザページに移動します。4)アプリにリダイレクトされます。5)ベリファイアを取得します。ただし、retrieveAccessToken(consumer、verifier)の呼び出しは、「サービスプロバイダーとの通信に失敗しました:null」というOAuthCommunicationExceptionで失敗します。
誰かが理由が何であるか知っていますか?requestTokenの取得に問題があるように見える人もいますが、それは問題なく機能します。私のアプリに、マルチパートアップロードに必要なapache-mime4j-0.6.jarとhttpmime-4.0.1.jarも含まれているのは問題ではないかと思います。