アプリが期待どおりに機能しない理由を 4 日間把握しようとしています。
私のアプリは twitter で OAuth を使用したい (機能している) ため、コールバック時に onNewIntent メソッドを入力する必要があります。それはそうではなく、その理由がわかりません。
twitter ボタンをクリックすると、資格情報を入力できる Web ページが開きます。次に、成功したことを示す画面が表示され、アプリにリダイレクトされます。アプリに戻りますが、onNewIntent メソッドは呼び出されません。onNewIntend メソッドの先頭にブレークポイントを設定し、デバッガーを起動しました。その方法にとどまらない!他の方法で停止するため、デバッガーにすることはできません。
私のログ ファイル (含まれています) では、下から 3 行目で、新しいインテントを開始していることがわかります。ここで何が起こっているのですか?
誰か説明してくれませんか?私は非常に混乱しています。
これは、twitterbutton がクリックされたときにトリガーされる私のコードです。
callBackURL = "myapp://twitactivity";
httpOauthConsumer = new CommonsHttpOAuthConsumer(consKey, consSec);
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);
startActivity(new Intent(Intent.ACTION_VIEW,Uri.parse(authUrl)));
これは、私の onNewIntent メソッドの開始コードです。
public void onNewIntent(Intent intent) {
super.onNewIntent(intent);
Log.i("onNewIntent", "Yep success.");
Uri uri = intent.getData();
if(uri != null && uri.toString().startsWith(callBackURL)) {
String verifier = uri.getQueryParameter(oauth.signpost.OAuth.OAUTH_VERIFIER);
etc......
マニフェストファイルには次のものもあります。
<activity android:name=".TwitterScreen">
<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="myapp" android:host="twitactivity" />
</intent-filter>
</activity>
そして、これは私のログファイルに表示されるものです:
01-24 10:23:36.064: INFO/ActivityManager(61): Displayed activity nl.gemoro.android.demo/.TwitterScreen: 6660 ms (total 6660 ms)
01-24 10:23:38.614: INFO/global(348): Default buffer size used in BufferedReader constructor. It would be better to be explicit if an 8k-char buffer is required.
01-24 10:23:44.025: INFO/ActivityManager(61): Starting activity: Intent { act=android.intent.action.VIEW dat=http://twitter.com/oauth/authorize?oauth_token=KjCUNMKg13OClyRjQff94QWKfoRBUpNLE2uF9cJkHA cmp=com.android.browser/.BrowserActivity }
01-24 10:23:44.185: INFO/ActivityManager(61): Start proc com.android.browser for activity com.android.browser/.BrowserActivity: pid=355 uid=10034 gids={3003, 1015}
01-24 10:23:44.724: INFO/ActivityThread(355): Publishing provider browser: com.android.browser.BrowserProvider
01-24 10:23:46.704: INFO/ActivityManager(61): Displayed activity com.android.browser/.BrowserActivity: 2544 ms (total 2544 ms)
01-24 10:23:53.624: WARN/KeyCharacterMap(355): No keyboard for id 0
01-24 10:23:53.624: WARN/KeyCharacterMap(355): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
01-24 10:23:54.574: DEBUG/dalvikvm(348): GC_EXPLICIT freed 3965 objects / 267064 bytes in 2364ms
01-24 10:24:01.064: INFO/ActivityManager(61): Starting activity: Intent { act=android.intent.action.VIEW cat=[android.intent.category.BROWSABLE] dat=myapp://twitactivity?oauth_token=KjCUNMKg13OClyRjQff94QWKfoRBUpNLE2uF9cJkHA&oauth_verifier=41owXswx5TsxHhRyiviFRkRvcpdekm7akRa2IFFM cmp=nl.gemoro.android.demo/.TwitterScreen }
01-24 10:24:02.174: INFO/global(348): Default buffer size used in BufferedReader constructor. It would be better to be explicit if an 8k-char buffer is required.
01-24 10:24:03.594: INFO/ActivityManager(61): Displayed activity nl.gemoro.android.demo/.TwitterScreen: 2412 ms (total 2412 ms)