2

Twitter を自分のアプリに統合しようとしていますが、機能しないようです。

これは私のコードです:

public class OAuthForTwitter extends Activity {

    private CommonsHttpOAuthConsumer httpOauthConsumer;
    private OAuthProvider httpOauthprovider;
    public final static String consumerKey = "{removed}";
    public final static String consumerSecret = "{removed}";
    private final String CALLBACKURL = "sosInternational:///HierBenIkNu";
    private Twitter twitter;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        doOAuth();
    }

    /**
     * Opens the browser using signpost jar with application specific
     * consumerkey and consumerSecret.
     */

    private void doOAuth() {
        try {
            httpOauthConsumer = new CommonsHttpOAuthConsumer(consumerKey, consumerSecret);
            httpOauthprovider = new DefaultOAuthProvider(
                    "http://twitter.com/oauth/request_token",
                    "http://twitter.com/oauth/access_token",
                    "http://twitter.com/oauth/authorize");
            String authUrl = httpOauthprovider.retrieveRequestToken(httpOauthConsumer, CALLBACKURL);
            this.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(authUrl)));
        } catch (Exception e) {
            Toast.makeText(this, e.getMessage(), Toast.LENGTH_LONG).show();
        }
    }

    @Override
    protected void onNewIntent(Intent intent) {

        super.onNewIntent(intent);

        Uri uri = intent.getData();
        if (uri != null && uri.toString().startsWith(CALLBACKURL)) {

            String verifier = uri
                    .getQueryParameter(oauth.signpost.OAuth.OAUTH_VERIFIER);

            try {
                // this will populate token and token_secret in consumer

                httpOauthprovider.retrieveAccessToken(httpOauthConsumer,
                        verifier);

                // TODO: you might want to store token and token_secret in you
                // app settings!!!!!!!!

                AccessToken a = new AccessToken(httpOauthConsumer.getToken(),
                        httpOauthConsumer.getTokenSecret());

                // initialize Twitter4J

                twitter = new TwitterFactory().getInstance();
                twitter.setOAuthConsumer(consumerKey, consumerSecret);
                twitter.setOAuthAccessToken(a);

                // create a tweet

                Date d = new Date(System.currentTimeMillis());
                String tweet = "#OAuth working! " + d.toLocaleString();

                // send the tweet

                twitter.updateStatus(tweet);

            } catch (Exception e) {

                Toast.makeText(this, e.getMessage(), Toast.LENGTH_LONG).show();
            }

        }
    }
}

Twitter サイトでの認証が完了すると、アプリにリダイレクトされるはずです。

しかし、代わりに、このページが見つかりません:

代替テキスト

私は AndroidManifest にこれを持っています:

<intent-filter>  
        <action android:name="android.intent.action.VIEW"></action>  
        <category android:name="android.intent.category.DEFAULT"></category>  
        <category android:name="android.intent.category.BROWSABLE"></category>  
        <data android:scheme="sosInternational" android:host="HierBenIkNu"></data>  
    </intent-filter>  

取得したキーを使用してアプリに戻るにはどうすればよいですか?

4

3 に答える 3

7

わかりました、それはかなりばかげた間違いでした。

<intent-filter>はアプリケーションの中にいませんでした..

これが今の様子です:

<activity 
        android:name=".OAuthForTwitter"
        android:label="@string/app_name"
        android:configChanges="orientation|keyboardHidden"
        android:launchMode="singleInstance">
        <intent-filter>  
            <action android:name="android.intent.action.VIEW"></action>  
            <category android:name="android.intent.category.DEFAULT"></category>  
            <category android:name="android.intent.category.BROWSABLE"></category>  
            <data android:scheme="sosInternational" android:host="OAuthForTwitter"></data>  
        </intent-filter>
    </activity>

この種のオフは機能します。アプリ全体を最初からロードするだけです。

アプリ全体を再起動せずに最後のアクティビティに「戻る」方法はありませんか?

于 2010-12-08T13:18:23.367 に答える
5

私はこれを解決しました。あなたが開発した方法とまったく同じではありませんが、わずかに異なる方法です。ここに私がしたことを説明する手順があります。

  1. Web ブラウザーで開く代わりに WebView を使用します。これを行う主な利点の 1 つは、URL リダイレクトを追跡できることです。

  2. setWebViewClientあなたのwebviewのメソッドを呼び出しshouldOverrideUrlLoading、あなたのクラスのメソッドをオーバーライドしてください。私は内部クラスを使用しました。

  3. メソッドに url パラメータがあります。独自のコールバック URL で始まるかどうかを確認します (注: この URL には、承認に必要なユーザー トークンとユーザー シークレットが含まれています)。

  4. タスクが完了したら、アクティビティを非表示にしたり、webView や必要なものを削除したりできます。

EDIT : これは、Web アプリケーションで通常使用される oAuth の方法であるため、xAuth の方法は必要ありません。(他のコミュニティメンバーが知らない場合)

それがあなたを助けることを願っています。

于 2010-12-10T05:17:06.620 に答える
0

コールバック URL は、Java コードでは (「sosInternational:///HierBenIkNu」ではなく)「sosInternational://HierBenIkNu」にする必要があります。

private final String CALLBACKURL = "sosInternational://HierBenIkNu";
于 2010-12-10T02:16:44.400 に答える