4

私の目的は、twitter4j を使用して Twitter のログインを許可することです。 これを参考にしました。

問題は、64 行目で を呼び出していることgetAuthenticationURl()です。実行すると、ユーザーのアカウントへのアプリ アクセスを許可/禁止できるページではなく、ログイン ページが表示されます。
ただし、変更するとgetAuthorizationUrl()、正しいページに移動します。

1) では、両者の違いは何ですか?

2) これは重要な質問です。以下のコードを提供しています。

package com.example.twitter;



import twitter4j.Twitter;
import twitter4j.TwitterException;
import twitter4j.TwitterFactory;
import twitter4j.http.AccessToken;
import twitter4j.http.RequestToken;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class WriteTweet extends Activity{
    public final static String consumerKey = "xxxxxxxxxxxxxxxxxx";
    public final static String consumerSecret = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
    private final String CALLBACKURL = "T4J_OAuth://callback";
    Twitter twitter;
    RequestToken requestToken;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        loginUser();
    }

    private void loginUser() {
        // TODO Auto-generated method stub
        try {
            twitter = new TwitterFactory().getInstance();
            twitter.setOAuthConsumer(consumerKey, consumerSecret);
            requestToken = twitter.getOAuthRequestToken(CALLBACKURL);
            String authUrl = requestToken.getAuthorizationURL();
            this.startActivity(new Intent(Intent.ACTION_VIEW, Uri
                    .parse(authUrl)));
        } catch (TwitterException ex) {
            Toast.makeText(this, ex.getMessage(), Toast.LENGTH_LONG).show();
            Log.e("in Main.OAuthLogin", ex.getMessage());
        }
    }
    @Override
    protected void onNewIntent(Intent intent) {
        Log.e("hi","hi");
        super.onNewIntent(intent);
        Uri uri = intent.getData();
        try {
            String verifier = uri.getQueryParameter("oauth_verifier");
            AccessToken accessToken = twitter.getOAuthAccessToken(requestToken,
                    verifier);
            String token = accessToken.getToken(), secret = accessToken
                    .getTokenSecret();
            displayTimeLine(token, secret); //after everything, display the first tweet 

        } catch (TwitterException ex) {
            Log.e("Main.onNewIntent", "" + ex.getMessage());
        }

    }
    @SuppressWarnings("deprecation")
    void displayTimeLine(String token, String secret) {
        Log.e("display","timeline");
    }

}

マニフェストは

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.twitter"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />
    <uses-permission android:name="android.permission.INTERNET"/>

    <application

        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>
        </activity>


        <activity android:name=".ListTweets" >

        </activity>
        <activity android:name=".WriteTweet"> 
                <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="T4J_OAuth" android:host="callback" />
                </intent-filter>
        </activity>
        <activity android:name=".ViewFollowers">

        </activity>
    </application>

</manifest>

問題は、 https://mobile.twitter.com/にリダイレクトさ れ、何が間違っているのかわかりません。getAuthenticationUrl()またはが使用されているかどうかに関係なく、問題は存在しgetAuthorizationUrl()ます。callback_urlTwitter のフィールドにダミー URL を入力しました。コードと Twitter ページで提供しなかった場合はcallbackurl、ピン番号が表示されます。しかし、それは私が望むものではありません。アプリにリダイレクトするには、Twitter が必要です。どうすればこれを達成できますか?

4

2 に答える 2

3

これが私が問題を回避した方法です。

  1. Web ビューを作成し、アプリ内から twitter の確認ページを読み込みます。

    vw = (WebView)findViewById(R.id.loginView);
    vw.setWebViewClient(new WebViewClient() {
        @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
            return super.shouldOverrideUrlLoading(view, url);
        }
    }); vw.loadUrl(authUrl);
    
  2. callback_url を受け取ったら、「 oauth_verifier 」を取得します。

                Uri uri = Uri.parse(url);
                String verifier = uri.getQueryParameter("oauth_verifier");
    
  3. この検証ツールを使用して、アクセスを取得し、必要なことを行います。私の場合、webview を破棄し、必要なアクティビティをロードします。

于 2012-09-01T15:20:46.773 に答える
2

以下の URL をコールバック URL として使用します。

public static final String  CALLBACK_URL = "x-oauthflow-twitter://callback";

Android アプリケーションでの Twitter 統合の詳細については、以下のリンクを参照してください。

ツイッター統合

于 2012-08-30T12:17:34.683 に答える