2011-06-02 7 views
1

私のアプリでの特定のメールリンクを処理するインテントフィルタを設定しました。これはAndroidの基本的なメールプログラムでうまくいきます。リンクをクリックすると、ブラウザーやアプリケーションを使用して開くかどうかを確認するメッセージが表示され、アプリケーションを選択すると正しく処理されます。同じことはGmailアプリの使用には当てはまりません。どうすればこのアプリを正しく扱うことができますか?インテントフィルタが動作しているように見えます - ブラウザまたはアプリケーションのプロンプトが表示されますが、アプリケーションを選択すると、強制終了されます。ここに私のlogcatからのエラーは、次のとおりです。Androidのブラウズ可能なインテントはGmailのリンクでは失敗しますが、デフォルトのメールクライアントで動作します

06-02 01:23:11.337: ERROR/AndroidRuntime(11145): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.android/com.example.android.Example}: java.lang.NullPointerException 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.os.Handler.dispatchMessage(Handler.java:99) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.os.Looper.loop(Looper.java:123) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at java.lang.reflect.Method.invokeNative(Native Method) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at java.lang.reflect.Method.invoke(Method.java:521) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at dalvik.system.NativeStart.main(Native Method) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145): Caused by: java.lang.NullPointerException 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at com.example.android.Example.onCreate(Example.java:301) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
06-02 01:23:11.337: ERROR/AndroidRuntime(11145):  ... 11 more 

はまた、ここでのonCreateで入ってくる意図を処理するための私のコードは次のとおりです。

if (getIntent().getCategories().contains("android.intent.category.BROWSABLE")){ 
    try{ 
     Uri uri = getIntent().getData(); 
     String url = uri.getFragment(); 
     //parse url and handle its contents 
    }catch(Exception e){ 
     Toast.makeText(this, "could not open url", Toast.LENGTH_LONG).show(); 
    } 
    } 

すべてのヘルプははるかに高く評価されるだろう!

答えて

2

getIntent()。カテゴリがない場合、getCategories()はnullを返します。問題を解決するために、このif文を次のように変更しました:

if (getIntent().getAction().equals("android.intent.action.VIEW")){...} 
関連する問題