1

yahooに統合すると上記のエラーが発生します

プロバイダーは以下で定義します

コード

provider = new CommonsHttpOAuthProvider(
                "https://api.login.yahoo.com/oauth/v2/get_request_token",
                "https://api.login.yahoo.com/oauth/v2/get_token",
                "https://api.login.yahoo.com/oauth/v2/request_auth");

Consumer と Oauth_Verifier

            consumer = new CommonsHttpOAuthConsumer(
                "ppp",
                "lll");

        consumer.setMessageSigner(new HmacSha1MessageSigner());

String oauth_verifier = uri
            .getQueryParameter(OAuth.OAUTH_VERIFIER);

yahoo api からトークンにアクセスしようとするとエラーが表示されます:-

oauth.signpost.exception.OAuthCommunicationException: Communication with the service provider failed: null

コードの下で実行すると、例外が上に来ます:-

 provider.retrieveAccessToken(consumer, oauth_verifier);
4

1 に答える 1

1

大きな編集

トークンの更新を処理する方法について計画がない限り、Signpost を使用しないことを強くお勧めします。Signpost には、これを実現する方法がありません。はるかに使いやすいScribeに切り替えました。残念ながら、これにもトークン リフレッシュを支援するメソッドはありませんが、ヘルパー メソッドはかなり簡単に作成できました。

Android で Yahoo API が 100% 動作するようになりました。Signpost で解決できず、Scribe に切り替える場合は、私のコードを投稿します。


これは最初から最後まで私のために働いています。キーを再利用することもできます。1 つのことを順不同で実行すると、トリッキーなことが起こります。これは、私がクリーンアップするつもりの方法で大まかなバージョンです。60分後にトークンを更新することを理解する必要があります.

Android マニフェスト

<activity
    android:name=".UpdaterActivity"
    android:label="@string/app_name"
    android:launchMode="singleInstance" >
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>
    <intent-filter> 
        <action android:name="android.intent.action.VIEW" /> 
        <category android:name="android.intent.category.DEFAULT" /> 
        <category android:name="android.intent.category.BROWSABLE" /> 
        <data android:scheme="yfbwa" android:host="oauth"></data> 
    </intent-filter> 
</activity>

UpdaterActivity.java

private static final String CONSUMER_KEY = "";
private static final String CONSUMER_SECRET = "";
private static final String REQUEST_TOKEN_URL = "https://api.login.yahoo.com/oauth/v2/get_request_token";
private static final String ACCESS_TOKEN_URL = "https://api.login.yahoo.com/oauth/v2/get_token";
private static final String AUTHORIZE_WEBSITE_URL = "https://api.login.yahoo.com/oauth/v2/request_auth";
private static final String CALLBACK_URL = "yfbwa://oauth";
private OAuthConsumer consumer;
private OAuthProvider provider;

@Override
protected void onCreate(Bundle savedInstanceState) {
    consumer = new CommonsHttpOAuthConsumer(CONSUMER_KEY, CONSUMER_SECRET); 
    provider = new CommonsHttpOAuthProvider(REQUEST_TOKEN_URL, ACCESS_TOKEN_URL, AUTHORIZE_WEBSITE_URL);
    if(getIsAuthorized() == 0) {
        callOAuth();
    } else {
        makeRequest("http://fantasysports.yahooapis.com/fantasy/v2/users;use_login=1/games;game_keys=308/teams?format=json");
    }
}

private void callOAuth() { 
    String url = provider.retrieveRequestToken(consumer, CALLBACK_URL);
    this.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(url))); 
}

@Override 
protected void onNewIntent(Intent intent) { 
    Uri data = intent.getData();
    String verifier = data.getQueryParameter(OAuth.OAUTH_VERIFIER);
    provider.retrieveAccessToken(consumer, URLDecoder.decode(verifier,"UTF-8"));
    writePrefs(consumer.getToken(), consumer.getTokenSecret());
    makeRequest("http://fantasysports.yahooapis.com/fantasy/v2/users;use_login=1/games;game_keys=308/teams?format=json");
}

private void makeRequest(String url) throws OAuthMessageSignerException, OAuthNotAuthorizedException, OAuthExpectationFailedException, OAuthCommunicationException, ClientProtocolException, IOException {
    String[] prefs = getPrefs();
    consumer.setTokenWithSecret(prefs[0], prefs[1]);
    HttpClient httpClient = new DefaultHttpClient();
    HttpGet request = new HttpGet(url);
    consumer.sign(request);
    HttpResponse response = httpClient.execute(request);
    String result = EntityUtils.toString(response.getEntity());
}

private void writePrefs(String token, String tokenSecret) {
    Editor prefsEditor = getSharedPreferences("ybfwa", MODE_PRIVATE).edit();
    prefsEditor.putString("token",token);
    prefsEditor.putString("tokenSecret",tokenSecret);
    prefsEditor.putInt("isAuthorized",1);
    prefsEditor.commit();
}

private String[] getPrefs() {
    String[] prefs = new String[2];
    SharedPreferences myPrefs = getSharedPreferences("ybfwa", MODE_PRIVATE);
    prefs[0] = myPrefs.getString("token", null);
    prefs[1] = myPrefs.getString("tokenSecret", null);
    return prefs;
}

private int getIsAuthorized() {
    SharedPreferences myPrefs = getSharedPreferences("ybfwa", MODE_PRIVATE);
    return myPrefs.getInt("isAuthorized", 0);
}
于 2013-04-19T18:11:54.173 に答える